Merge branch 'core-rcu-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull RCU updates from Ingo Molnar: "The main changes are: - Documentation updates, including fixes to the design-level requirements documentation and a fixed version of the design-level data-structure documentation. These fixes include removing cartoons and getting rid of the html/htmlx duplication. - Further improvements to the new-age expedited grace periods. - Miscellaneous fixes. - Torture-test changes, including a new rcuperf module for measuring RCU grace-period performance and scalability, which is useful for the expedited-grace-period changes" * 'core-rcu-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (56 commits) rcutorture: Add boot-time adjustment of leaf fanout rcutorture: Add irqs-disabled test for call_rcu() rcutorture: Dump trace buffer upon shutdown rcutorture: Don't rebuild identical kernel rcutorture: Add OS-jitter capability documentation: Add documentation for RCU's major data structures rcutorture: Convert test duration to seconds early torture: Kill qemu, not parent process torture: Clarify refusal to run more than one torture test rcutorture: Consider FROZEN hotplug notifier transitions rcutorture: Remove redundant initialization to zero rcuperf: Do not wake up shutdown wait queue if "shutdown" is false. rcutorture: Add largish-system rcuperf scenario rcutorture: Avoid RCU CPU stall warning and RT throttling rcutorture: Add rcuperf holdoff boot parameter to reduce interference rcutorture: Make scripts analyze rcuperf trace data, if present rcutorture: Make rcuperf collect expedited event-trace data rcutorture: Print measure of batching efficiency rcutorture: Set rcuperf writer kthreads to real-time priority rcutorture: Bind rcuperf reader/writer kthreads to CPUs ...
474
Documentation/RCU/Design/Data-Structures/BigTreeClassicRCU.svg
Normal file
@ -0,0 +1,474 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:28:20 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 3.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="9.1in"
|
||||||
|
height="8.9in"
|
||||||
|
viewBox="-66 -66 10932 10707"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="BigTreeClassicRCU.fig">
|
||||||
|
<metadata
|
||||||
|
id="metadata106">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs104">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow1Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow1Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3864"
|
||||||
|
d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z "
|
||||||
|
style="fill-rule:evenodd;stroke:#000000;stroke-width:1.0pt;"
|
||||||
|
transform="scale(0.4) rotate(180) translate(10,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="973"
|
||||||
|
inkscape:window-height="1137"
|
||||||
|
id="namedview102"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="0.9743589"
|
||||||
|
inkscape:cx="409.50003"
|
||||||
|
inkscape:cy="400.49997"
|
||||||
|
inkscape:window-x="915"
|
||||||
|
inkscape:window-y="24"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="10800"
|
||||||
|
height="5625"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1125"
|
||||||
|
y="3600"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3825"
|
||||||
|
y="900"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="6525"
|
||||||
|
y="3600"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect12" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="3375,6525 3375,5046 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.9934641;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline14" />
|
||||||
|
<!-- Arrowhead on XXXpoint 3375 6525 - 3375 4860-->
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="7425"
|
||||||
|
cy="6075"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle18" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="7875"
|
||||||
|
cy="6075"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle20" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="8325"
|
||||||
|
cy="6075"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle22" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="2025"
|
||||||
|
cy="6075"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle24" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="2475"
|
||||||
|
cy="6075"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle26" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="2925"
|
||||||
|
cy="6075"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle28" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4725"
|
||||||
|
cy="4275"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle30" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="5175"
|
||||||
|
cy="4275"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle32" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="5625"
|
||||||
|
cy="4275"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle34" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="2025"
|
||||||
|
y="6525"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect36" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2475,3600 3975,2310 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.9934641;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline38" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2475 3600 - 4116 2190-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="7875,3600 6372,2310 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.9934641;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline42" />
|
||||||
|
<!-- Arrowhead on XXXpoint 7875 3600 - 6231 2190-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="6975,8775 6975,5046 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.9934641;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline46" />
|
||||||
|
<!-- Arrowhead on XXXpoint 6975 8775 - 6975 4860-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1575,8775 1575,5046 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.9934641;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline50" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1575 8775 - 1575 4860-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="8775,6525 8775,5046 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.9934641;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline54" />
|
||||||
|
<!-- Arrowhead on XXXpoint 8775 6525 - 8775 4860-->
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1575"
|
||||||
|
y="9225"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text58">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1575"
|
||||||
|
y="9675"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text60">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1575"
|
||||||
|
y="10350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text62">CPU 0</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3375"
|
||||||
|
y="6975"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text64">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3375"
|
||||||
|
y="7425"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text66">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3375"
|
||||||
|
y="8100"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text68">CPU 15</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6975"
|
||||||
|
y="9225"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text70">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6975"
|
||||||
|
y="9675"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text72">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6975"
|
||||||
|
y="10350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text74">CPU 1007</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8730"
|
||||||
|
y="6930"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text76">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8730"
|
||||||
|
y="7380"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text78">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8730"
|
||||||
|
y="8055"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text80">CPU 1023</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="225"
|
||||||
|
y="450"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text82">struct rcu_state</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2475"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text84">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2475"
|
||||||
|
y="4500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text86">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="7875"
|
||||||
|
y="4500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text88">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="7875"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text90">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5175"
|
||||||
|
y="1350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text92">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5175"
|
||||||
|
y="1800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text94">rcu_node</text>
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="225"
|
||||||
|
y="8775"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect96" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="5625"
|
||||||
|
y="8775"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect98" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="7380"
|
||||||
|
y="6480"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect100" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 12 KiB |
499
Documentation/RCU/Design/Data-Structures/BigTreeClassicRCUBH.svg
Normal file
@ -0,0 +1,499 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:26:09 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 2.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="5.7in"
|
||||||
|
height="6.6in"
|
||||||
|
viewBox="-44 -44 6838 7888"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="BigTreeClassicRCUBH.fig">
|
||||||
|
<metadata
|
||||||
|
id="metadata110">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs108">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow1Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow1Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3868"
|
||||||
|
d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z "
|
||||||
|
style="fill-rule:evenodd;stroke:#000000;stroke-width:1.0pt;"
|
||||||
|
transform="scale(0.4) rotate(180) translate(10,0)" />
|
||||||
|
</marker>
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow2Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow2Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3886"
|
||||||
|
style="fill-rule:evenodd;stroke-width:0.62500000;stroke-linejoin:round;"
|
||||||
|
d="M 8.7185878,4.0337352 L -2.2072895,0.016013256 L 8.7185884,-4.0017078 C 6.9730900,-1.6296469 6.9831476,1.6157441 8.7185878,4.0337352 z "
|
||||||
|
transform="scale(0.6) rotate(180) translate(0,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="878"
|
||||||
|
inkscape:window-height="1148"
|
||||||
|
id="namedview106"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="1.3547758"
|
||||||
|
inkscape:cx="256.5"
|
||||||
|
inkscape:cy="297"
|
||||||
|
inkscape:window-x="45"
|
||||||
|
inkscape:window-y="24"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="450"
|
||||||
|
y="0"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4950"
|
||||||
|
y="4950"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="750"
|
||||||
|
y="600"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="450"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect12" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="300"
|
||||||
|
y="1050"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect14" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="2850"
|
||||||
|
cy="3900"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle16" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="3150"
|
||||||
|
cy="3900"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle18" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="3450"
|
||||||
|
cy="3900"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle20" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1350"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle22" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1650"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle24" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1950"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle26" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4350"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle28" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4650"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle30" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4950"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle32" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1350,3450 2350,2590 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.0045575;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline34" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1350 3450 - 2444 2510-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4950,3450 3948,2590 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.0045575;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline38" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4950 3450 - 3854 2510-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="750"
|
||||||
|
y="3450"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect42" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,5400 2250,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.0045575;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline44" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2250 5400 - 2250 4290-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1500"
|
||||||
|
y="5400"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect48" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="300"
|
||||||
|
y="6600"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect50" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3750"
|
||||||
|
y="3450"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect52" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4500"
|
||||||
|
y="5400"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect54" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3300"
|
||||||
|
y="6600"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect56" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="2250"
|
||||||
|
y="1650"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect58" />
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6450"
|
||||||
|
y="300"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text60">rcu_bh</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="1950"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text62">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="2250"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text64">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1650"
|
||||||
|
y="3750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text66">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1650"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text68">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4650"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text70">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4650"
|
||||||
|
y="3750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text72">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="5700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text74">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="6000"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text76">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="6900"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text78">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text80">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5250"
|
||||||
|
y="5700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text82">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5250"
|
||||||
|
y="6000"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text84">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="6900"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text86">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text88">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="450"
|
||||||
|
y="1350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text90">struct rcu_state</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6000"
|
||||||
|
y="750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text92">rcu_sched</text>
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,5400 5250,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.0045575;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline94" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 5400 - 5250 4290-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,6600 4050,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.0045575;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline98" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 6600 - 4050 4290-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1050,6600 1050,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.0045575;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline102" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1050 6600 - 1050 4290-->
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 13 KiB |
@ -0,0 +1,695 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:20:02 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 2.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="5.7in"
|
||||||
|
height="8.6in"
|
||||||
|
viewBox="-44 -44 6838 10288"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="BigTreeClassicRCUBHdyntick.fig">
|
||||||
|
<metadata
|
||||||
|
id="metadata166">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs164">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow1Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow1Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3924"
|
||||||
|
d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z "
|
||||||
|
style="fill-rule:evenodd;stroke:#000000;stroke-width:1.0pt;"
|
||||||
|
transform="scale(0.4) rotate(180) translate(10,0)" />
|
||||||
|
</marker>
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow2Lend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow2Lend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3936"
|
||||||
|
style="fill-rule:evenodd;stroke-width:0.62500000;stroke-linejoin:round;"
|
||||||
|
d="M 8.7185878,4.0337352 L -2.2072895,0.016013256 L 8.7185884,-4.0017078 C 6.9730900,-1.6296469 6.9831476,1.6157441 8.7185878,4.0337352 z "
|
||||||
|
transform="scale(1.1) rotate(180) translate(1,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="845"
|
||||||
|
inkscape:window-height="988"
|
||||||
|
id="namedview162"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="1.0452196"
|
||||||
|
inkscape:cx="256.5"
|
||||||
|
inkscape:cy="387.00003"
|
||||||
|
inkscape:window-x="356"
|
||||||
|
inkscape:window-y="61"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="450"
|
||||||
|
y="0"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4950"
|
||||||
|
y="4950"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="750"
|
||||||
|
y="600"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,8100 5688,5912 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline12" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 8100 - 5710 5790-->
|
||||||
|
<polyline
|
||||||
|
points="5714 6068 5704 5822 5598 6044 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline14" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,9300 4486,7262 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline16" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 9300 - 4512 7140-->
|
||||||
|
<polyline
|
||||||
|
points="4514 7418 4506 7172 4396 7394 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline18" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1040,9300 1476,7262 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline20" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1040 9300 - 1502 7140-->
|
||||||
|
<polyline
|
||||||
|
points="1504 7418 1496 7172 1386 7394 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline22" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2240,8100 2676,6062 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline24" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2240 8100 - 2702 5940-->
|
||||||
|
<polyline
|
||||||
|
points="2704 6218 2696 5972 2586 6194 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline26" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="450"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect28" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="300"
|
||||||
|
y="1050"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect30" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1350,3450 2350,2590 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.0045575;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline32" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1350 3450 - 2444 2510-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4950,3450 3948,2590 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.0045575;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline36" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4950 3450 - 3854 2510-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,6600 4050,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00455750000000066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline40" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 6600 - 4050 4290-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1050,6600 1050,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00455750000000066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline44" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1050 6600 - 1050 4290-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,5400 2250,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00455750000000066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline48" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2250 5400 - 2250 4290-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,8100 2250,6364 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30;stroke-linejoin:miter;stroke-linecap:butt;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline52" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2250 8100 - 2250 6240-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1050,9300 1050,7564 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30;stroke-linejoin:miter;stroke-linecap:butt;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline56" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1050 9300 - 1050 7440-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,9300 4050,7564 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30;stroke-linejoin:miter;stroke-linecap:butt;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline60" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 9300 - 4050 7440-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,8100 5250,6364 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30;stroke-linejoin:miter;stroke-linecap:butt;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline64" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 8100 - 5250 6240-->
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="2850"
|
||||||
|
cy="3900"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle68" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="3150"
|
||||||
|
cy="3900"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle70" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="3450"
|
||||||
|
cy="3900"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle72" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1350"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle74" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1650"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle76" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1950"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle78" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4350"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle80" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4650"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle82" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4950"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle84" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="750"
|
||||||
|
y="3450"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect86" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="300"
|
||||||
|
y="6600"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect88" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3750"
|
||||||
|
y="3450"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect90" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4500"
|
||||||
|
y="5400"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect92" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3300"
|
||||||
|
y="6600"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect94" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="2250"
|
||||||
|
y="1650"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect96" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="9300"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect98" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1350"
|
||||||
|
y="8100"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect100" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3000"
|
||||||
|
y="9300"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect102" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4350"
|
||||||
|
y="8100"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect104" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1500"
|
||||||
|
y="5400"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect106" />
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6450"
|
||||||
|
y="300"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text108">rcu_bh</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="1950"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text110">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="2250"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text112">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1650"
|
||||||
|
y="3750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text114">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1650"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text116">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4650"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text118">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4650"
|
||||||
|
y="3750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text120">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="5700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text122">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="6000"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text124">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="6900"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text126">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text128">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5250"
|
||||||
|
y="5700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text130">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5250"
|
||||||
|
y="6000"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text132">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="6900"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text134">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text136">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="450"
|
||||||
|
y="1350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text138">struct rcu_state</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="9600"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text140">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="9900"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text142">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="9600"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text144">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="9900"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text146">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2400"
|
||||||
|
y="8400"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text148">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2400"
|
||||||
|
y="8700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text150">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5400"
|
||||||
|
y="8400"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text152">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5400"
|
||||||
|
y="8700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text154">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6000"
|
||||||
|
y="750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text156">rcu_sched</text>
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,5400 5250,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00455750000000066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline158" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 5400 - 5250 4290-->
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 19 KiB |
@ -0,0 +1,741 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:32:59 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 2.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="6.1in"
|
||||||
|
height="8.9in"
|
||||||
|
viewBox="-44 -44 7288 10738"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="BigTreePreemptRCUBHdyntick.fig">
|
||||||
|
<metadata
|
||||||
|
id="metadata182">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs180">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow1Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow1Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3940"
|
||||||
|
d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z "
|
||||||
|
style="fill-rule:evenodd;stroke:#000000;stroke-width:1.0pt;"
|
||||||
|
transform="scale(0.4) rotate(180) translate(10,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="874"
|
||||||
|
inkscape:window-height="1148"
|
||||||
|
id="namedview178"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="1.2097379"
|
||||||
|
inkscape:cx="274.5"
|
||||||
|
inkscape:cy="400.49997"
|
||||||
|
inkscape:window-x="946"
|
||||||
|
inkscape:window-y="24"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="900"
|
||||||
|
y="0"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1200"
|
||||||
|
y="600"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="5400"
|
||||||
|
y="4950"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="450"
|
||||||
|
y="450"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect12" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="750"
|
||||||
|
y="1050"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect14" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4950"
|
||||||
|
y="5400"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect16" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,8550 5688,6362 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline18" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 8550 - 5710 6240-->
|
||||||
|
<polyline
|
||||||
|
points="5714 6518 5704 6272 5598 6494 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline20" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,9750 4486,7712 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline22" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 9750 - 4512 7590-->
|
||||||
|
<polyline
|
||||||
|
points="4514 7868 4506 7622 4396 7844 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline24" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1040,9750 1476,7712 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline26" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1040 9750 - 1502 7590-->
|
||||||
|
<polyline
|
||||||
|
points="1504 7868 1496 7622 1386 7844 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline28" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2240,8550 2676,6512 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline30" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2240 8550 - 2702 6390-->
|
||||||
|
<polyline
|
||||||
|
points="2704 6668 2696 6422 2586 6644 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline32" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,9750 5682,6360 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline34" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 9750 - 5736 6246-->
|
||||||
|
<polyline
|
||||||
|
points="5672 6518 5722 6276 5562 6466 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline36" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1010,9750 2642,6360 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline38" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1010 9750 - 2696 6246-->
|
||||||
|
<polyline
|
||||||
|
points="2632 6518 2682 6276 2522 6466 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline40" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="900"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect42" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="300"
|
||||||
|
y="1500"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect44" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1350,3900 2350,3040 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00205472;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline46" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1350 3900 - 2444 2960-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4950,3900 3948,3040 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00205472;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline50" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4950 3900 - 3854 2960-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,7050 4050,4864 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00205472;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline54" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 7050 - 4050 4740-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1050,7050 1050,4864 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00205472;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline58" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1050 7050 - 1050 4740-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,5850 2250,4864 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00205472;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline62" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2250 5850 - 2250 4740-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,8550 2250,6814 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline66" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2250 8550 - 2250 6690-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1050,9750 1050,8014 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30.00205472;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline70" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1050 9750 - 1050 7890-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,9750 4050,8014 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30.00205472;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline74" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 9750 - 4050 7890-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,8550 5250,6814 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline78" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 8550 - 5250 6690-->
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="2850"
|
||||||
|
cy="4350"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle82" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="3150"
|
||||||
|
cy="4350"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle84" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="3450"
|
||||||
|
cy="4350"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle86" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1350"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle88" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1650"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle90" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1950"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle92" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4350"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle94" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4650"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle96" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4950"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle98" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="750"
|
||||||
|
y="3900"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect100" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="300"
|
||||||
|
y="7050"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect102" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3750"
|
||||||
|
y="3900"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect104" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4500"
|
||||||
|
y="5850"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect106" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3300"
|
||||||
|
y="7050"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect108" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="2250"
|
||||||
|
y="2100"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect110" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="9750"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect112" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1350"
|
||||||
|
y="8550"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect114" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3000"
|
||||||
|
y="9750"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect116" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4350"
|
||||||
|
y="8550"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect118" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1500"
|
||||||
|
y="5850"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect120" />
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6450"
|
||||||
|
y="750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text122">rcu_bh</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="2400"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text124">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="2700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text126">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1650"
|
||||||
|
y="4200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text128">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1650"
|
||||||
|
y="4500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text130">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4650"
|
||||||
|
y="4500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text132">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4650"
|
||||||
|
y="4200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text134">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="6150"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text136">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="6450"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text138">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="7350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text140">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="7650"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text142">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5250"
|
||||||
|
y="6150"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text144">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5250"
|
||||||
|
y="6450"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text146">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="7350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text148">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="7650"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text150">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="450"
|
||||||
|
y="1800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text152">struct rcu_state</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="10050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text154">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="10350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text156">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="10050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text158">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="10350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text160">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2400"
|
||||||
|
y="8850"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text162">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2400"
|
||||||
|
y="9150"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text164">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5400"
|
||||||
|
y="8850"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text166">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5400"
|
||||||
|
y="9150"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text168">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6900"
|
||||||
|
y="300"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text170">rcu_preempt</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6000"
|
||||||
|
y="1200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text172">rcu_sched</text>
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,5850 5250,4864 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00205472;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline174" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 5850 - 5250 4740-->
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 20 KiB |
@ -0,0 +1,858 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:29:48 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 2.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="7.4in"
|
||||||
|
height="9.9in"
|
||||||
|
viewBox="-44 -44 8938 11938"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="BigTreePreemptRCUBHdyntickCB.svg">
|
||||||
|
<metadata
|
||||||
|
id="metadata212">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs210">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow1Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow1Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3970"
|
||||||
|
d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z "
|
||||||
|
style="fill-rule:evenodd;stroke:#000000;stroke-width:1.0pt;"
|
||||||
|
transform="scale(0.4) rotate(180) translate(10,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="881"
|
||||||
|
inkscape:window-height="1128"
|
||||||
|
id="namedview208"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="1.0195195"
|
||||||
|
inkscape:cx="333"
|
||||||
|
inkscape:cy="445.49997"
|
||||||
|
inkscape:window-x="936"
|
||||||
|
inkscape:window-y="24"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="900"
|
||||||
|
y="0"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1200"
|
||||||
|
y="600"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="5400"
|
||||||
|
y="4950"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="450"
|
||||||
|
y="450"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect12" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="750"
|
||||||
|
y="1050"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect14" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4950"
|
||||||
|
y="5400"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect16" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,8550 5688,6362 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline18" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 8550 - 5710 6240-->
|
||||||
|
<polyline
|
||||||
|
points="5714 6518 5704 6272 5598 6494 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline20" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,9750 4486,7712 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline22" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 9750 - 4512 7590-->
|
||||||
|
<polyline
|
||||||
|
points="4514 7868 4506 7622 4396 7844 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline24" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1040,9750 1476,7712 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline26" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1040 9750 - 1502 7590-->
|
||||||
|
<polyline
|
||||||
|
points="1504 7868 1496 7622 1386 7844 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline28" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2240,8550 2676,6512 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline30" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2240 8550 - 2702 6390-->
|
||||||
|
<polyline
|
||||||
|
points="2704 6668 2696 6422 2586 6644 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline32" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,9600 5692,6062 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline34" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 9600 - 5744 5948-->
|
||||||
|
<polyline
|
||||||
|
points="5682 6220 5730 5978 5574 6170 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline36" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1086,9600 2728,6062 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline38" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1086 9600 - 2780 5948-->
|
||||||
|
<polyline
|
||||||
|
points="2718 6220 2766 5978 2610 6170 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline40" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="900"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect42" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="300"
|
||||||
|
y="1500"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect44" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1350,3900 2350,3040 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:29.99463964;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline46" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1350 3900 - 2444 2960-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4950,3900 3948,3040 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:29.99463964;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline50" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4950 3900 - 3854 2960-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,7050 4050,4864 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:29.99463964;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline54" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 7050 - 4050 4740-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1050,7050 1050,4864 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:29.99463964;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline58" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1050 7050 - 1050 4740-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,5850 2250,4864 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:29.99463964;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline62" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2250 5850 - 2250 4740-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,8550 2250,6814 "
|
||||||
|
style="stroke:#00ff00;stroke-width:29.99463964;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline66" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2250 8550 - 2250 6690-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1050,9750 1050,8014 "
|
||||||
|
style="stroke:#00ff00;stroke-width:29.99463964;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline70" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1050 9750 - 1050 7890-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,9750 4050,8014 "
|
||||||
|
style="stroke:#00ff00;stroke-width:29.99463964;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline74" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 9750 - 4050 7890-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,8550 5250,6814 "
|
||||||
|
style="stroke:#00ff00;stroke-width:29.99463964;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline78" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 8550 - 5250 6690-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="6000,6300 8048,7910 "
|
||||||
|
style="stroke:#87cfff;stroke-width:30;stroke-linejoin:miter;stroke-linecap:butt;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline82" />
|
||||||
|
<!-- Arrowhead on XXXpoint 6000 6300 - 8146 7986-->
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="2850"
|
||||||
|
cy="4350"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle86" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="3150"
|
||||||
|
cy="4350"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle88" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="3450"
|
||||||
|
cy="4350"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle90" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1350"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle92" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1650"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle94" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1950"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle96" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4350"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle98" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4650"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle100" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4950"
|
||||||
|
cy="5550"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle102" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="7350"
|
||||||
|
y="7950"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect104" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="7350"
|
||||||
|
y="9450"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect106" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="8100,8850 8100,9384 "
|
||||||
|
style="stroke:#000000;stroke-width:30;stroke-linejoin:miter;stroke-linecap:butt;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline108" />
|
||||||
|
<!-- Arrowhead on XXXpoint 8100 8850 - 8100 9510-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="7350"
|
||||||
|
y="10950"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect112" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="8100,10350 8100,10884 "
|
||||||
|
style="stroke:#000000;stroke-width:30;stroke-linejoin:miter;stroke-linecap:butt;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline114" />
|
||||||
|
<!-- Arrowhead on XXXpoint 8100 10350 - 8100 11010-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="750"
|
||||||
|
y="3900"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect118" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="300"
|
||||||
|
y="7050"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect120" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3750"
|
||||||
|
y="3900"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect122" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4500"
|
||||||
|
y="5850"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect124" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3300"
|
||||||
|
y="7050"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect126" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="2250"
|
||||||
|
y="2100"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect128" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="9750"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect130" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1350"
|
||||||
|
y="8550"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect132" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3000"
|
||||||
|
y="9750"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect134" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4350"
|
||||||
|
y="8550"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect136" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1500"
|
||||||
|
y="5850"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect138" />
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8100"
|
||||||
|
y="8250"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text140">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8100"
|
||||||
|
y="8550"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text142">rcu_head</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8100"
|
||||||
|
y="9750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text144">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8100"
|
||||||
|
y="10050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text146">rcu_head</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8100"
|
||||||
|
y="11250"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text148">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8100"
|
||||||
|
y="11550"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text150">rcu_head</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6000"
|
||||||
|
y="1200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text152">rcu_sched</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6450"
|
||||||
|
y="750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text154">rcu_bh</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="2400"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text156">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="2700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text158">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1650"
|
||||||
|
y="4200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text160">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1650"
|
||||||
|
y="4500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text162">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4650"
|
||||||
|
y="4500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text164">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4650"
|
||||||
|
y="4200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text166">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="6150"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text168">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="6450"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text170">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="7350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text172">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="7650"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text174">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5250"
|
||||||
|
y="6150"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text176">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5250"
|
||||||
|
y="6450"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text178">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="7350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text180">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="7650"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text182">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="450"
|
||||||
|
y="1800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text184">struct rcu_state</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="10050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text186">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="10350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text188">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="10050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text190">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="10350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text192">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2400"
|
||||||
|
y="8850"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text194">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2400"
|
||||||
|
y="9150"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text196">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5400"
|
||||||
|
y="8850"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text198">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5400"
|
||||||
|
y="9150"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text200">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6900"
|
||||||
|
y="300"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text202">rcu_preempt</text>
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,5850 5250,4864 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:29.99463964;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline204" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 5850 - 5250 4740-->
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 24 KiB |
1333
Documentation/RCU/Design/Data-Structures/Data-Structures.html
Normal file
939
Documentation/RCU/Design/Data-Structures/HugeTreeClassicRCU.svg
Normal file
@ -0,0 +1,939 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:37:22 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 3.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="15.1in"
|
||||||
|
height="11.2in"
|
||||||
|
viewBox="-66 -66 18087 13407"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="HugeTreeClassicRCU.fig">
|
||||||
|
<metadata
|
||||||
|
id="metadata224">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs222">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow1Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow1Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3982"
|
||||||
|
d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z "
|
||||||
|
style="fill-rule:evenodd;stroke:#000000;stroke-width:1.0pt;"
|
||||||
|
transform="scale(0.4) rotate(180) translate(10,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="1134"
|
||||||
|
inkscape:window-height="789"
|
||||||
|
id="namedview220"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="0.60515873"
|
||||||
|
inkscape:cx="679.5"
|
||||||
|
inkscape:cy="504"
|
||||||
|
inkscape:window-x="786"
|
||||||
|
inkscape:window-y="24"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="450"
|
||||||
|
y="0"
|
||||||
|
width="17100"
|
||||||
|
height="8325"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="11025"
|
||||||
|
y="3600"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4275"
|
||||||
|
y="3600"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="5400"
|
||||||
|
y="6300"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect12" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="9900"
|
||||||
|
y="6300"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect14" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="14400"
|
||||||
|
y="6300"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect16" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="900"
|
||||||
|
y="6300"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect18" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="7650"
|
||||||
|
y="900"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect20" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="3150,9225 3150,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline22" />
|
||||||
|
<!-- Arrowhead on XXXpoint 3150 9225 - 3150 7560-->
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="8550"
|
||||||
|
cy="4275"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle26" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="9000"
|
||||||
|
cy="4275"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle28" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="9450"
|
||||||
|
cy="4275"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle30" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="6750,6300 8250,5010 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline32" />
|
||||||
|
<!-- Arrowhead on XXXpoint 6750 6300 - 8391 4890-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="11250,6300 9747,5010 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline36" />
|
||||||
|
<!-- Arrowhead on XXXpoint 11250 6300 - 9606 4890-->
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="13950"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle40" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="13500"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle42" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="13050"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle44" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="9450"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle46" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="9000"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle48" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="8550"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle50" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4950"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle52" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4500"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle54" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4050"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle56" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1800"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle58" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="2250"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle60" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="2700"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle62" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="15300"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle64" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="15750"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle66" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="16200"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle68" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="10800"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle70" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="11250"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle72" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="11700"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle74" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="6300"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle76" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="6750"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle78" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="7200"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle80" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="11475"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect82" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1800"
|
||||||
|
y="9225"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect84" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4500"
|
||||||
|
y="11475"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect86" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="6300"
|
||||||
|
y="9270"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect88" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="8955"
|
||||||
|
y="11475"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect90" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10755"
|
||||||
|
y="9270"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect92" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="13455"
|
||||||
|
y="11475"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect94" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="15255"
|
||||||
|
y="9270"
|
||||||
|
width="2700"
|
||||||
|
height="1800"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect96" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="11700,3600 10197,2310 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline98" />
|
||||||
|
<!-- Arrowhead on XXXpoint 11700 3600 - 10056 2190-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="6300,3600 7800,2310 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline102" />
|
||||||
|
<!-- Arrowhead on XXXpoint 6300 3600 - 7941 2190-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="3150,6300 4650,5010 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline106" />
|
||||||
|
<!-- Arrowhead on XXXpoint 3150 6300 - 4791 4890-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="14850,6300 13347,5010 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline110" />
|
||||||
|
<!-- Arrowhead on XXXpoint 14850 6300 - 13206 4890-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1350,11475 1350,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline114" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1350 11475 - 1350 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="16650,9225 16650,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline118" />
|
||||||
|
<!-- Arrowhead on XXXpoint 16650 9225 - 16650 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="14850,11475 14850,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline122" />
|
||||||
|
<!-- Arrowhead on XXXpoint 14850 11475 - 14850 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="12150,9225 12150,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline126" />
|
||||||
|
<!-- Arrowhead on XXXpoint 12150 9225 - 12150 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="10350,11475 10350,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline130" />
|
||||||
|
<!-- Arrowhead on XXXpoint 10350 11475 - 10350 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="7650,9225 7650,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline134" />
|
||||||
|
<!-- Arrowhead on XXXpoint 7650 9225 - 7650 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5850,11475 5850,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:44.99790066;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline138" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5850 11475 - 5850 7560-->
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="12375"
|
||||||
|
y="4500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text142">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="12375"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text144">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5625"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text146">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5625"
|
||||||
|
y="4500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text148">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6750"
|
||||||
|
y="6750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text150">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6750"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text152">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11250"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text154">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11250"
|
||||||
|
y="6750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text156">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="15750"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text158">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="15750"
|
||||||
|
y="6750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text160">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="6750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text162">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text164">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1350"
|
||||||
|
y="13050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text166">CPU 0</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1350"
|
||||||
|
y="11925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text168">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1350"
|
||||||
|
y="12375"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text170">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="10800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text172">CPU 15</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="9675"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text174">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="10125"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text176">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5850"
|
||||||
|
y="11925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text178">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5850"
|
||||||
|
y="12375"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text180">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5850"
|
||||||
|
y="13050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text182">CPU 21823</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="7650"
|
||||||
|
y="10845"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text184">CPU 21839</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="7650"
|
||||||
|
y="10170"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text186">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="7650"
|
||||||
|
y="9720"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text188">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="10305"
|
||||||
|
y="11925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text190">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="10305"
|
||||||
|
y="12375"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text192">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="10305"
|
||||||
|
y="13050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text194">CPU 43679</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="12105"
|
||||||
|
y="10845"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text196">CPU 43695</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="12105"
|
||||||
|
y="10170"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text198">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="12105"
|
||||||
|
y="9720"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text200">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="14805"
|
||||||
|
y="11925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text202">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="14805"
|
||||||
|
y="12375"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text204">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="14805"
|
||||||
|
y="13050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text206">CPU 65519</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="16605"
|
||||||
|
y="10845"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text208">CPU 65535</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="16605"
|
||||||
|
y="10170"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text210">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="16605"
|
||||||
|
y="9720"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text212">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="675"
|
||||||
|
y="450"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text214">struct rcu_state</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="9000"
|
||||||
|
y="1350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text216">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="9000"
|
||||||
|
y="1800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text218">rcu_node</text>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 25 KiB |
828
Documentation/RCU/Design/Data-Structures/TreeLevel.svg
Normal file
@ -0,0 +1,828 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:41:29 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 3.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="17.7in"
|
||||||
|
height="10.4in"
|
||||||
|
viewBox="-66 -66 21237 12507"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="TreeLevel.fig">
|
||||||
|
<metadata
|
||||||
|
id="metadata216">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs214">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow1Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow1Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3974"
|
||||||
|
d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z "
|
||||||
|
style="fill-rule:evenodd;stroke:#000000;stroke-width:1.0pt;"
|
||||||
|
transform="scale(0.4) rotate(180) translate(10,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="1023"
|
||||||
|
inkscape:window-height="1148"
|
||||||
|
id="namedview212"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="0.55869424"
|
||||||
|
inkscape:cx="796.50006"
|
||||||
|
inkscape:cy="467.99997"
|
||||||
|
inkscape:window-x="897"
|
||||||
|
inkscape:window-y="24"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="20655"
|
||||||
|
height="8325"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="14130"
|
||||||
|
y="3600"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="7380"
|
||||||
|
y="3600"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="8505"
|
||||||
|
y="6300"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect12" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="13005"
|
||||||
|
y="6300"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect14" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="17505"
|
||||||
|
y="6300"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect16" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4005"
|
||||||
|
y="6300"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect18" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10755"
|
||||||
|
y="900"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect20" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="6255,9225 6255,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline22" />
|
||||||
|
<!-- Arrowhead on XXXpoint 6255 9225 - 6255 7560-->
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="11655"
|
||||||
|
cy="4275"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle26" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="12105"
|
||||||
|
cy="4275"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle28" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="12555"
|
||||||
|
cy="4275"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle30" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="9855,6300 11355,5010 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline32" />
|
||||||
|
<!-- Arrowhead on XXXpoint 9855 6300 - 11496 4890-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="14355,6300 12852,5010 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline36" />
|
||||||
|
<!-- Arrowhead on XXXpoint 14355 6300 - 12711 4890-->
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="17055"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle40" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="16605"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle42" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="16155"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle44" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="12555"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle46" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="12105"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle48" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="11655"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle50" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="8055"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle52" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="7605"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle54" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="7155"
|
||||||
|
cy="6975"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle56" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4905"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle58" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="5355"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle60" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="5805"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle62" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="18405"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle64" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="18855"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle66" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="19305"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle68" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="13905"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle70" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="14355"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle72" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="14805"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle74" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="9405"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle76" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="9855"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle78" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="10305"
|
||||||
|
cy="8775"
|
||||||
|
r="114"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:21;"
|
||||||
|
id="circle80" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="225"
|
||||||
|
y="1125"
|
||||||
|
width="3150"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:21; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect82" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="225"
|
||||||
|
y="2250"
|
||||||
|
width="3150"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:21; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect84" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="225"
|
||||||
|
y="3375"
|
||||||
|
width="3150"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:21; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect86" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="14805,3600 13302,2310 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline88" />
|
||||||
|
<!-- Arrowhead on XXXpoint 14805 3600 - 13161 2190-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="9405,3600 10905,2310 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline92" />
|
||||||
|
<!-- Arrowhead on XXXpoint 9405 3600 - 11046 2190-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="6255,6300 7755,5010 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline96" />
|
||||||
|
<!-- Arrowhead on XXXpoint 6255 6300 - 7896 4890-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="17955,6300 16452,5010 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline100" />
|
||||||
|
<!-- Arrowhead on XXXpoint 17955 6300 - 16311 4890-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4455,11025 4455,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline104" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4455 11025 - 4455 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="19755,9225 19755,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline108" />
|
||||||
|
<!-- Arrowhead on XXXpoint 19755 9225 - 19755 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="17955,11025 17955,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline112" />
|
||||||
|
<!-- Arrowhead on XXXpoint 17955 11025 - 17955 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="15255,9225 15255,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline116" />
|
||||||
|
<!-- Arrowhead on XXXpoint 15255 9225 - 15255 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="13455,11025 13455,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline120" />
|
||||||
|
<!-- Arrowhead on XXXpoint 13455 11025 - 13455 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="10755,9225 10755,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline124" />
|
||||||
|
<!-- Arrowhead on XXXpoint 10755 9225 - 10755 7560-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="8955,11025 8955,7746 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline128" />
|
||||||
|
<!-- Arrowhead on XXXpoint 8955 11025 - 8955 7560-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="12105"
|
||||||
|
y="11025"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect132" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="13905"
|
||||||
|
y="9225"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect134" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="16605"
|
||||||
|
y="11025"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect136" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="18405"
|
||||||
|
y="9225"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect138" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="9405"
|
||||||
|
y="9225"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect140" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="7605"
|
||||||
|
y="11025"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect142" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4905"
|
||||||
|
y="9225"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect144" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3105"
|
||||||
|
y="11025"
|
||||||
|
width="2700"
|
||||||
|
height="1350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect146" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="3375,1575 10701,1575 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline148" />
|
||||||
|
<!-- Arrowhead on XXXpoint 3375 1575 - 10890 1575-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="3375,3825 4050,3825 4050,5400 2700,5400 2700,6975 3951,6975 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline152" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2700 6975 - 4140 6975-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="3375,2700 5175,2700 5175,4275 7326,4275 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline156" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5175 4275 - 7515 4275-->
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="15480"
|
||||||
|
y="4500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text160">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="15480"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text162">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8730"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text164">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8730"
|
||||||
|
y="4500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text166">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="9855"
|
||||||
|
y="6750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text168">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="9855"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text170">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="14355"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text172">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="14355"
|
||||||
|
y="6750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text174">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="18855"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text176">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="18855"
|
||||||
|
y="6750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text178">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5355"
|
||||||
|
y="6750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text180">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5355"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text182">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="450"
|
||||||
|
y="1800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text184">->level[0]</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="450"
|
||||||
|
y="2925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text186">->level[1]</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="450"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text188">->level[2]</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="12105"
|
||||||
|
y="1350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text190">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="12105"
|
||||||
|
y="1800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text192">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6255"
|
||||||
|
y="10125"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text194">CPU 15</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4455"
|
||||||
|
y="11925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text196">CPU 0</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="19755"
|
||||||
|
y="10125"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text198">CPU 65535</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="17955"
|
||||||
|
y="11925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text200">CPU 65519</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="15255"
|
||||||
|
y="10125"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text202">CPU 43695</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="13455"
|
||||||
|
y="11925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text204">CPU 43679</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="10755"
|
||||||
|
y="10125"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text206">CPU 21839</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="8955"
|
||||||
|
y="11925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text208">CPU 21823</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="225"
|
||||||
|
y="450"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="288"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text210">struct rcu_state</text>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 23 KiB |
305
Documentation/RCU/Design/Data-Structures/TreeMapping.svg
Normal file
@ -0,0 +1,305 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:43:22 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 1.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="3.1in"
|
||||||
|
height="0.9in"
|
||||||
|
viewBox="-12 -12 3699 1074"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="TreeMapping.fig">
|
||||||
|
<metadata
|
||||||
|
id="metadata66">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs64">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow2Lend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow2Lend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3836"
|
||||||
|
style="fill-rule:evenodd;stroke-width:0.62500000;stroke-linejoin:round;"
|
||||||
|
d="M 8.7185878,4.0337352 L -2.2072895,0.016013256 L 8.7185884,-4.0017078 C 6.9730900,-1.6296469 6.9831476,1.6157441 8.7185878,4.0337352 z "
|
||||||
|
transform="scale(1.1) rotate(180) translate(1,0)" />
|
||||||
|
</marker>
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow2Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow2Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3842"
|
||||||
|
style="fill-rule:evenodd;stroke-width:0.62500000;stroke-linejoin:round;"
|
||||||
|
d="M 8.7185878,4.0337352 L -2.2072895,0.016013256 L 8.7185884,-4.0017078 C 6.9730900,-1.6296469 6.9831476,1.6157441 8.7185878,4.0337352 z "
|
||||||
|
transform="scale(0.6) rotate(180) translate(0,0)" />
|
||||||
|
</marker>
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow1Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow1Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3824"
|
||||||
|
d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z "
|
||||||
|
style="fill-rule:evenodd;stroke:#000000;stroke-width:1.0pt;"
|
||||||
|
transform="scale(0.4) rotate(180) translate(10,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="991"
|
||||||
|
inkscape:window-height="606"
|
||||||
|
id="namedview62"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="3.0752688"
|
||||||
|
inkscape:cx="139.5"
|
||||||
|
inkscape:cy="40.5"
|
||||||
|
inkscape:window-x="891"
|
||||||
|
inkscape:window-y="177"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="3675"
|
||||||
|
height="1050"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="75"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="600"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1125"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect12" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1650"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect14" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="2175"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect16" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3225"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect18" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="675,375 675,150 300,150 300,358 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00088889;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline20" />
|
||||||
|
<!-- Arrowhead on XXXpoint 300 150 - 300 390-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1200,675 1200,900 300,900 300,691 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00088889;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline24" />
|
||||||
|
<!-- Arrowhead on XXXpoint 300 900 - 300 660-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1725,375 1725,150 900,150 900,358 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00088889;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline28" />
|
||||||
|
<!-- Arrowhead on XXXpoint 900 150 - 900 390-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,375 2250,75 825,75 825,358 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00088889;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline32" />
|
||||||
|
<!-- Arrowhead on XXXpoint 825 75 - 825 390-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2775,675 2775,900 1425,900 1425,691 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00088889;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline36" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1425 900 - 1425 660-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="3300,675 3300,975 1350,975 1350,691 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00088889;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline40" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1350 975 - 1350 660-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="2700"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect44" />
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="300"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text46">0:7 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1350"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text48">4:7 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1875"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text50">0:1 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2400"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text52">2:3 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2925"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text54">4:5 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3450"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text56">6:7 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="825"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text58">0:3 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3600"
|
||||||
|
y="150"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text60">struct rcu_state</text>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 9.0 KiB |
380
Documentation/RCU/Design/Data-Structures/TreeMappingLevel.svg
Normal file
@ -0,0 +1,380 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:45:19 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 1.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="3.1in"
|
||||||
|
height="1.8in"
|
||||||
|
viewBox="-12 -12 3699 2124"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="TreeMappingLevel.svg">
|
||||||
|
<metadata
|
||||||
|
id="metadata98">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title />
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs96">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow2Lend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow2Lend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3868"
|
||||||
|
style="fill-rule:evenodd;stroke-width:0.62500000;stroke-linejoin:round;"
|
||||||
|
d="M 8.7185878,4.0337352 L -2.2072895,0.016013256 L 8.7185884,-4.0017078 C 6.9730900,-1.6296469 6.9831476,1.6157441 8.7185878,4.0337352 z "
|
||||||
|
transform="scale(1.1) rotate(180) translate(1,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="1598"
|
||||||
|
inkscape:window-height="1211"
|
||||||
|
id="namedview94"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="5.2508961"
|
||||||
|
inkscape:cx="139.5"
|
||||||
|
inkscape:cy="81"
|
||||||
|
inkscape:window-x="840"
|
||||||
|
inkscape:window-y="122"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="3675"
|
||||||
|
height="2100"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="75"
|
||||||
|
y="1350"
|
||||||
|
width="750"
|
||||||
|
height="225"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="75"
|
||||||
|
y="1575"
|
||||||
|
width="750"
|
||||||
|
height="225"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="75"
|
||||||
|
y="1800"
|
||||||
|
width="750"
|
||||||
|
height="225"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect12" />
|
||||||
|
<!-- Arc -->
|
||||||
|
<path
|
||||||
|
style="stroke:#000000;stroke-width:7;stroke-linecap:butt;"
|
||||||
|
d="M 1800,900 A 118 118 0 0 0 1800 1125 "
|
||||||
|
id="path14" />
|
||||||
|
<!-- Arc -->
|
||||||
|
<path
|
||||||
|
style="stroke:#000000;stroke-width:7;stroke-linecap:butt;"
|
||||||
|
d="M 750,900 A 75 75 0 0 0 750 1050 "
|
||||||
|
id="path16" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="750,900 750,691 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00025806;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline18" />
|
||||||
|
<!-- Arrowhead on XXXpoint 750 900 - 750 660-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="75"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect22" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="600"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect24" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1650"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect26" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="2175"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect28" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3225"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect30" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="675,375 675,150 300,150 300,358 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00025806;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline32" />
|
||||||
|
<!-- Arrowhead on XXXpoint 300 150 - 300 390-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1725,375 1725,150 900,150 900,358 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00025806;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline36" />
|
||||||
|
<!-- Arrowhead on XXXpoint 900 150 - 900 390-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,375 2250,75 825,75 825,358 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00025806;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline40" />
|
||||||
|
<!-- Arrowhead on XXXpoint 825 75 - 825 390-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2775,675 2775,975 1425,975 1425,691 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00025806;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline44" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1425 975 - 1425 660-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="2700"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect48" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1125"
|
||||||
|
y="375"
|
||||||
|
width="375"
|
||||||
|
height="300"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect50" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="3300,675 3300,1050 1350,1050 1350,691 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00025806;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline52" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1350 1050 - 1350 660-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="825,1425 975,1425 975,1200 225,1200 225,691 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00025806;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline56" />
|
||||||
|
<!-- Arrowhead on XXXpoint 225 1200 - 225 660-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1200,675 1200,975 300,975 300,691 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00025806;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline60" />
|
||||||
|
<!-- Arrowhead on XXXpoint 300 975 - 300 660-->
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="150"
|
||||||
|
y="1500"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="108"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text64">->level[0]</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="150"
|
||||||
|
y="1725"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="108"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text66">->level[1]</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="150"
|
||||||
|
y="1950"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="108"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text68">->level[2]</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="300"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text70">0:7 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1350"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text72">4:7 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1875"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text74">0:1 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2400"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text76">2:3 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2925"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text78">4:5 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3450"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text80">6:7 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="825"
|
||||||
|
y="525"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Times"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text82">0:3 </text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3600"
|
||||||
|
y="150"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="96"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text84">struct rcu_state</text>
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="825,1875 1800,1875 1800,1125 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00025806;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:none"
|
||||||
|
id="polyline86" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1800,900 1800,691 "
|
||||||
|
style="stroke:#000000;stroke-width:7.00025806;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow2Lend)"
|
||||||
|
id="polyline88" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1800 900 - 1800 660-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="825,1650 1200,1650 1200,1125 750,1125 750,1050 "
|
||||||
|
style="stroke:#000000;stroke-width:7; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline92" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 11 KiB |
843
Documentation/RCU/Design/Data-Structures/blkd_task.svg
Normal file
@ -0,0 +1,843 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:35:03 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 2.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="10.1in"
|
||||||
|
height="8.6in"
|
||||||
|
viewBox="-44 -44 12088 10288"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="blkd_task.fig">
|
||||||
|
<metadata
|
||||||
|
id="metadata212">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs210">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow1Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow1Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3970"
|
||||||
|
d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z "
|
||||||
|
style="fill-rule:evenodd;stroke:#000000;stroke-width:1.0pt;"
|
||||||
|
transform="scale(0.4) rotate(180) translate(10,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="1087"
|
||||||
|
inkscape:window-height="1144"
|
||||||
|
id="namedview208"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="1.0495049"
|
||||||
|
inkscape:cx="454.50003"
|
||||||
|
inkscape:cy="387.00003"
|
||||||
|
inkscape:window-x="833"
|
||||||
|
inkscape:window-y="28"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="450"
|
||||||
|
y="0"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4950"
|
||||||
|
y="4950"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="750"
|
||||||
|
y="600"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,8100 5688,5912 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline12" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 8100 - 5710 5790-->
|
||||||
|
<polyline
|
||||||
|
points="5714 6068 5704 5822 5598 6044 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline14" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,9300 4486,7262 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline16" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 9300 - 4512 7140-->
|
||||||
|
<polyline
|
||||||
|
points="4514 7418 4506 7172 4396 7394 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline18" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1040,9300 1476,7262 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline20" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1040 9300 - 1502 7140-->
|
||||||
|
<polyline
|
||||||
|
points="1504 7418 1496 7172 1386 7394 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline22" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2240,8100 2676,6062 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="polyline24" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2240 8100 - 2702 5940-->
|
||||||
|
<polyline
|
||||||
|
points="2704 6218 2696 5972 2586 6194 "
|
||||||
|
style="stroke:#00ff00;stroke-width:14;stroke-miterlimit:8; "
|
||||||
|
id="polyline26" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="450"
|
||||||
|
width="6300"
|
||||||
|
height="7350"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffffff; "
|
||||||
|
id="rect28" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="300"
|
||||||
|
y="1050"
|
||||||
|
width="5700"
|
||||||
|
height="3750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffff00; "
|
||||||
|
id="rect30" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1350,3450 2350,2590 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline32" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1350 3450 - 2444 2510-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4950,3450 3948,2590 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline36" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4950 3450 - 3854 2510-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,6600 4050,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline40" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 6600 - 4050 4290-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1050,6600 1050,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline44" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1050 6600 - 1050 4290-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,5400 2250,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline48" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2250 5400 - 2250 4290-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="2250,8100 2250,6364 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline52" />
|
||||||
|
<!-- Arrowhead on XXXpoint 2250 8100 - 2250 6240-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="1050,9300 1050,7564 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline56" />
|
||||||
|
<!-- Arrowhead on XXXpoint 1050 9300 - 1050 7440-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="4050,9300 4050,7564 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline60" />
|
||||||
|
<!-- Arrowhead on XXXpoint 4050 9300 - 4050 7440-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,8100 5250,6364 "
|
||||||
|
style="stroke:#00ff00;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline64" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 8100 - 5250 6240-->
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="2850"
|
||||||
|
cy="3900"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle68" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="3150"
|
||||||
|
cy="3900"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle70" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="3450"
|
||||||
|
cy="3900"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle72" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1350"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle74" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1650"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle76" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="1950"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle78" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4350"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle80" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4650"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle82" />
|
||||||
|
<!-- Circle -->
|
||||||
|
<circle
|
||||||
|
cx="4950"
|
||||||
|
cy="5100"
|
||||||
|
r="76"
|
||||||
|
style="fill:#000000;stroke:#000000;stroke-width:14;"
|
||||||
|
id="circle84" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="750"
|
||||||
|
y="3450"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect86" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="300"
|
||||||
|
y="6600"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect88" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4500"
|
||||||
|
y="5400"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect90" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3300"
|
||||||
|
y="6600"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect92" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="2250"
|
||||||
|
y="1650"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect94" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="9300"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect96" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1350"
|
||||||
|
y="8100"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect98" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3000"
|
||||||
|
y="9300"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect100" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="4350"
|
||||||
|
y="8100"
|
||||||
|
width="2100"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#00ff00; "
|
||||||
|
id="rect102" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="1500"
|
||||||
|
y="5400"
|
||||||
|
width="1500"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect104" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polygon
|
||||||
|
points="5550,3450 7350,2850 7350,5100 5550,4350 5550,3450 "
|
||||||
|
style="stroke:#000000;stroke-width:14; stroke-linejoin:miter; stroke-linecap:butt; stroke-dasharray:120 120;fill:#ffbfbf; "
|
||||||
|
id="polygon106" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="9300,3150 10734,3150 "
|
||||||
|
style="stroke:#000000;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline108" />
|
||||||
|
<!-- Arrowhead on XXXpoint 9300 3150 - 10860 3150-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10800"
|
||||||
|
y="2850"
|
||||||
|
width="1200"
|
||||||
|
height="750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect112" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="11400,3600 11400,4284 "
|
||||||
|
style="stroke:#000000;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline114" />
|
||||||
|
<!-- Arrowhead on XXXpoint 11400 3600 - 11400 4410-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10800"
|
||||||
|
y="4350"
|
||||||
|
width="1200"
|
||||||
|
height="750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect118" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="11400,5100 11400,5784 "
|
||||||
|
style="stroke:#000000;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline120" />
|
||||||
|
<!-- Arrowhead on XXXpoint 11400 5100 - 11400 5910-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10800"
|
||||||
|
y="5850"
|
||||||
|
width="1200"
|
||||||
|
height="750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect124" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="9300,3900 9900,3900 9900,4650 10734,4650 "
|
||||||
|
style="stroke:#000000;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline126" />
|
||||||
|
<!-- Arrowhead on XXXpoint 9900 4650 - 10860 4650-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="9300,4650 9600,4650 9600,6150 10734,6150 "
|
||||||
|
style="stroke:#000000;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline130" />
|
||||||
|
<!-- Arrowhead on XXXpoint 9600 6150 - 10860 6150-->
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6450"
|
||||||
|
y="300"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text134">rcu_bh</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="1950"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text136">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="3150"
|
||||||
|
y="2250"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text138">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1650"
|
||||||
|
y="3750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text140">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1650"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text142">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="5700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text144">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2250"
|
||||||
|
y="6000"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text146">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="6900"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text148">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text150">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5250"
|
||||||
|
y="5700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text152">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5250"
|
||||||
|
y="6000"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text154">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="6900"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text156">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="7200"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text158">rcu_data</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="450"
|
||||||
|
y="1350"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text160">struct rcu_state</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="9600"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text162">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="1050"
|
||||||
|
y="9900"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text164">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="9600"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text166">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4050"
|
||||||
|
y="9900"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text168">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2400"
|
||||||
|
y="8400"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text170">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="2400"
|
||||||
|
y="8700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text172">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5400"
|
||||||
|
y="8400"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text174">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="5400"
|
||||||
|
y="8700"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text176">rcu_dynticks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="6000"
|
||||||
|
y="750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="end"
|
||||||
|
id="text178">rcu_sched</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11400"
|
||||||
|
y="3300"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="216"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text180">T3</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11400"
|
||||||
|
y="4800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="216"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text182">T2</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11400"
|
||||||
|
y="6300"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="216"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text184">T1</text>
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="5250,5400 5250,4414 "
|
||||||
|
style="stroke:#00d1d1;stroke-width:30.00057884;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline186" />
|
||||||
|
<!-- Arrowhead on XXXpoint 5250 5400 - 5250 4290-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="3750"
|
||||||
|
y="3450"
|
||||||
|
width="1800"
|
||||||
|
height="900"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect190" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="7350"
|
||||||
|
y="2850"
|
||||||
|
width="1950"
|
||||||
|
height="750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect192" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="7350"
|
||||||
|
y="3600"
|
||||||
|
width="1950"
|
||||||
|
height="750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect194" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="7350"
|
||||||
|
y="4350"
|
||||||
|
width="1950"
|
||||||
|
height="750"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:30; stroke-linejoin:miter; stroke-linecap:butt; fill:#ffbfbf; "
|
||||||
|
id="rect196" />
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4650"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text198">rcu_node</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="4650"
|
||||||
|
y="3750"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text200">struct</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="7500"
|
||||||
|
y="3300"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text202">blkd_tasks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="7500"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text204">gp_tasks</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="7500"
|
||||||
|
y="4800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="192"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text206">exp_tasks</text>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 24 KiB |
396
Documentation/RCU/Design/Data-Structures/nxtlist.svg
Normal file
@ -0,0 +1,396 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Creator: fig2dev Version 3.2 Patchlevel 5e -->
|
||||||
|
|
||||||
|
<!-- CreationDate: Wed Dec 9 17:39:46 2015 -->
|
||||||
|
|
||||||
|
<!-- Magnification: 3.000 -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="10.4in"
|
||||||
|
height="10.4in"
|
||||||
|
viewBox="-66 -66 12507 12507"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="nxtlist.fig">
|
||||||
|
<metadata
|
||||||
|
id="metadata94">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs92">
|
||||||
|
<marker
|
||||||
|
inkscape:stockid="Arrow1Mend"
|
||||||
|
orient="auto"
|
||||||
|
refY="0.0"
|
||||||
|
refX="0.0"
|
||||||
|
id="Arrow1Mend"
|
||||||
|
style="overflow:visible;">
|
||||||
|
<path
|
||||||
|
id="path3852"
|
||||||
|
d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z "
|
||||||
|
style="fill-rule:evenodd;stroke:#000000;stroke-width:1.0pt;"
|
||||||
|
transform="scale(0.4) rotate(180) translate(10,0)" />
|
||||||
|
</marker>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="925"
|
||||||
|
inkscape:window-height="928"
|
||||||
|
id="namedview90"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="0.80021373"
|
||||||
|
inkscape:cx="467.99997"
|
||||||
|
inkscape:cy="467.99997"
|
||||||
|
inkscape:window-x="948"
|
||||||
|
inkscape:window-y="73"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="g4" />
|
||||||
|
<g
|
||||||
|
style="stroke-width:.025in; fill:none"
|
||||||
|
id="g4">
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="7875"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect6" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="1125"
|
||||||
|
width="7875"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect8" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="2250"
|
||||||
|
width="7875"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect10" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="3375"
|
||||||
|
width="7875"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect12" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="0"
|
||||||
|
y="4500"
|
||||||
|
width="7875"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; fill:#87cfff; "
|
||||||
|
id="rect14" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10575"
|
||||||
|
y="0"
|
||||||
|
width="1800"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect16" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10575"
|
||||||
|
y="1125"
|
||||||
|
width="1800"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect18" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="11475,2250 11475,3276 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline20" />
|
||||||
|
<!-- Arrowhead on XXXpoint 11475 2250 - 11475 3465-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10575"
|
||||||
|
y="6750"
|
||||||
|
width="1800"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect24" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10575"
|
||||||
|
y="7875"
|
||||||
|
width="1800"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect26" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10575"
|
||||||
|
y="10125"
|
||||||
|
width="1800"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect28" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10575"
|
||||||
|
y="11250"
|
||||||
|
width="1800"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect30" />
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10575"
|
||||||
|
y="3375"
|
||||||
|
width="1800"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect32" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="11475,5625 11475,6651 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline34" />
|
||||||
|
<!-- Arrowhead on XXXpoint 11475 5625 - 11475 6840-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="7875,225 10476,225 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline38" />
|
||||||
|
<!-- Arrowhead on XXXpoint 7875 225 - 10665 225-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="7875,1350 9675,1350 9675,675 7971,675 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline42" />
|
||||||
|
<!-- Arrowhead on XXXpoint 9675 675 - 7785 675-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="7875,2475 9675,2475 9675,4725 10476,4725 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline46" />
|
||||||
|
<!-- Arrowhead on XXXpoint 9675 4725 - 10665 4725-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="7875,3600 9225,3600 9225,5175 10476,5175 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline50" />
|
||||||
|
<!-- Arrowhead on XXXpoint 9225 5175 - 10665 5175-->
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="7875,4725 8775,4725 8775,11475 10476,11475 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline54" />
|
||||||
|
<!-- Arrowhead on XXXpoint 8775 11475 - 10665 11475-->
|
||||||
|
<!-- Line: box -->
|
||||||
|
<rect
|
||||||
|
x="10575"
|
||||||
|
y="4500"
|
||||||
|
width="1800"
|
||||||
|
height="1125"
|
||||||
|
rx="0"
|
||||||
|
style="stroke:#000000;stroke-width:45; stroke-linejoin:miter; stroke-linecap:butt; "
|
||||||
|
id="rect58" />
|
||||||
|
<!-- Line -->
|
||||||
|
<polyline
|
||||||
|
points="11475,9000 11475,10026 "
|
||||||
|
style="stroke:#000000;stroke-width:45.00382345;stroke-linejoin:miter;stroke-linecap:butt;stroke-miterlimit:4;stroke-dasharray:none;marker-end:url(#Arrow1Mend)"
|
||||||
|
id="polyline60" />
|
||||||
|
<!-- Arrowhead on XXXpoint 11475 9000 - 11475 10215-->
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="225"
|
||||||
|
y="675"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text64">nxtlist</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="225"
|
||||||
|
y="1800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text66">nxttail[RCU_DONE_TAIL]</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="225"
|
||||||
|
y="2925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text68">nxttail[RCU_WAIT_TAIL]</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="225"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text70">nxttail[RCU_NEXT_READY_TAIL]</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="225"
|
||||||
|
y="5175"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Courier"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="bold"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="start"
|
||||||
|
id="text72">nxttail[RCU_NEXT_TAIL]</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11475"
|
||||||
|
y="675"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text74">CB 1</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11475"
|
||||||
|
y="1800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text76">next</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11475"
|
||||||
|
y="7425"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text78">CB 3</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11475"
|
||||||
|
y="8550"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text80">next</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11475"
|
||||||
|
y="10800"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text82">CB 4</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11475"
|
||||||
|
y="11925"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text84">next</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11475"
|
||||||
|
y="4050"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text86">CB 2</text>
|
||||||
|
<!-- Text -->
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
x="11475"
|
||||||
|
y="5175"
|
||||||
|
fill="#000000"
|
||||||
|
font-family="Helvetica"
|
||||||
|
font-style="normal"
|
||||||
|
font-weight="normal"
|
||||||
|
font-size="324"
|
||||||
|
text-anchor="middle"
|
||||||
|
id="text88">next</text>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 11 KiB |
Before Width: | Height: | Size: 98 KiB |
@ -1,237 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Creator: fig2dev Version 3.2 Patchlevel 5d -->
|
|
||||||
|
|
||||||
<!-- CreationDate: Tue Mar 4 18:34:25 2014 -->
|
|
||||||
|
|
||||||
<!-- Magnification: 3.000 -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="1089.1382"
|
|
||||||
height="668.21368"
|
|
||||||
viewBox="-2121 -36 14554.634 8876.4061"
|
|
||||||
id="svg2"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="0.48.3.1 r9886"
|
|
||||||
sodipodi:docname="RCUApplicability.svg">
|
|
||||||
<metadata
|
|
||||||
id="metadata40">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
<dc:title />
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<defs
|
|
||||||
id="defs38" />
|
|
||||||
<sodipodi:namedview
|
|
||||||
pagecolor="#ffffff"
|
|
||||||
bordercolor="#666666"
|
|
||||||
borderopacity="1"
|
|
||||||
objecttolerance="10"
|
|
||||||
gridtolerance="10"
|
|
||||||
guidetolerance="10"
|
|
||||||
inkscape:pageopacity="0"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:window-width="849"
|
|
||||||
inkscape:window-height="639"
|
|
||||||
id="namedview36"
|
|
||||||
showgrid="false"
|
|
||||||
inkscape:zoom="0.51326165"
|
|
||||||
inkscape:cx="544.56912"
|
|
||||||
inkscape:cy="334.10686"
|
|
||||||
inkscape:window-x="149"
|
|
||||||
inkscape:window-y="448"
|
|
||||||
inkscape:window-maximized="0"
|
|
||||||
inkscape:current-layer="g4"
|
|
||||||
fit-margin-top="5"
|
|
||||||
fit-margin-left="5"
|
|
||||||
fit-margin-right="5"
|
|
||||||
fit-margin-bottom="5" />
|
|
||||||
<g
|
|
||||||
style="fill:none;stroke-width:0.025in"
|
|
||||||
id="g4"
|
|
||||||
transform="translate(-2043.6828,14.791398)">
|
|
||||||
<!-- Line: box -->
|
|
||||||
<rect
|
|
||||||
x="0"
|
|
||||||
y="0"
|
|
||||||
width="14400"
|
|
||||||
height="8775"
|
|
||||||
rx="0"
|
|
||||||
style="fill:#ffa1a1;stroke:#000000;stroke-width:21;stroke-linecap:butt;stroke-linejoin:miter"
|
|
||||||
id="rect6" />
|
|
||||||
<!-- Line: box -->
|
|
||||||
<rect
|
|
||||||
x="1350"
|
|
||||||
y="0"
|
|
||||||
width="11700"
|
|
||||||
height="6075"
|
|
||||||
rx="0"
|
|
||||||
style="fill:#ffff00;stroke:#000000;stroke-width:21;stroke-linecap:butt;stroke-linejoin:miter"
|
|
||||||
id="rect8" />
|
|
||||||
<!-- Line: box -->
|
|
||||||
<rect
|
|
||||||
x="2700"
|
|
||||||
y="0"
|
|
||||||
width="9000"
|
|
||||||
height="4275"
|
|
||||||
rx="0"
|
|
||||||
style="fill:#00ff00;stroke:#000000;stroke-width:21;stroke-linecap:butt;stroke-linejoin:miter"
|
|
||||||
id="rect10" />
|
|
||||||
<!-- Line: box -->
|
|
||||||
<rect
|
|
||||||
x="4050"
|
|
||||||
y="0"
|
|
||||||
width="6300"
|
|
||||||
height="2475"
|
|
||||||
rx="0"
|
|
||||||
style="fill:#87cfff;stroke:#000000;stroke-width:21;stroke-linecap:butt;stroke-linejoin:miter"
|
|
||||||
id="rect12" />
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="900"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text14"
|
|
||||||
sodipodi:linespacing="125%"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"><tspan
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
id="tspan3017">Read-Mostly, Stale &</tspan></text>
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="1350"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text16"
|
|
||||||
sodipodi:linespacing="125%"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"><tspan
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
id="tspan3019">Inconsistent Data OK</tspan></text>
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="1800"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text18"
|
|
||||||
sodipodi:linespacing="125%"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"><tspan
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
id="tspan3021">(RCU Works Great!!!)</tspan></text>
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="3825"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text20"
|
|
||||||
sodipodi:linespacing="125%"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"><tspan
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
id="tspan3023">(RCU Works Well)</tspan></text>
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="3375"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text22"
|
|
||||||
sodipodi:linespacing="125%"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"><tspan
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
id="tspan3025">Read-Mostly, Need Consistent Data</tspan></text>
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="5175"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text24"
|
|
||||||
sodipodi:linespacing="125%"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"><tspan
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
id="tspan3027">Read-Write, Need Consistent Data</tspan></text>
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="6975"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text26"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
sodipodi:linespacing="125%">Update-Mostly, Need Consistent Data</text>
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="5625"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text28"
|
|
||||||
sodipodi:linespacing="125%"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"><tspan
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
id="tspan3029">(RCU Might Be OK...)</tspan></text>
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="7875"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text30"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
sodipodi:linespacing="125%">(1) Provide Existence Guarantees For Update-Friendly Mechanisms</text>
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="8325"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text32"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
sodipodi:linespacing="125%">(2) Provide Wait-Free Read-Side Primitives for Real-Time Use)</text>
|
|
||||||
<!-- Text -->
|
|
||||||
<text
|
|
||||||
xml:space="preserve"
|
|
||||||
x="7200"
|
|
||||||
y="7425"
|
|
||||||
font-style="normal"
|
|
||||||
font-weight="normal"
|
|
||||||
font-size="324"
|
|
||||||
id="text34"
|
|
||||||
style="font-size:427.63009644px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;writing-mode:lr-tb;text-anchor:middle;fill:#000000;font-family:Nimbus Sans L;-inkscape-font-specification:Nimbus Sans L"
|
|
||||||
sodipodi:linespacing="125%">(RCU is Very Unlikely to be the Right Tool For The Job, But it Can:</text>
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 10 KiB |
@ -1,108 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
#
|
|
||||||
# Usage: sh htmlqqz.sh file
|
|
||||||
#
|
|
||||||
# Extracts and converts quick quizzes in a proto-HTML document file.htmlx.
|
|
||||||
# Commands, all of which must be on a line by themselves:
|
|
||||||
#
|
|
||||||
# "<p>@@QQ@@": Start of a quick quiz.
|
|
||||||
# "<p>@@QQA@@": Start of a quick-quiz answer.
|
|
||||||
# "<p>@@QQE@@": End of a quick-quiz answer, and thus of the quick quiz.
|
|
||||||
# "<p>@@QQAL@@": Place to put quick-quiz answer list.
|
|
||||||
#
|
|
||||||
# Places the result in file.html.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, you can access it online at
|
|
||||||
# http://www.gnu.org/licenses/gpl-2.0.html.
|
|
||||||
#
|
|
||||||
# Copyright (c) 2013 Paul E. McKenney, IBM Corporation.
|
|
||||||
|
|
||||||
fn=$1
|
|
||||||
if test ! -r $fn.htmlx
|
|
||||||
then
|
|
||||||
echo "Error: $fn.htmlx unreadable."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "<!-- DO NOT HAND EDIT. -->" > $fn.html
|
|
||||||
echo "<!-- Instead, edit $fn.htmlx and run 'sh htmlqqz.sh $fn' -->" >> $fn.html
|
|
||||||
awk < $fn.htmlx >> $fn.html '
|
|
||||||
|
|
||||||
state == "" && $1 != "<p>@@QQ@@" && $1 != "<p>@@QQAL@@" {
|
|
||||||
print $0;
|
|
||||||
if ($0 ~ /^<p>@@QQ/)
|
|
||||||
print "Bad Quick Quiz command: " NR " (expected <p>@@QQ@@ or <p>@@QQAL@@)." > "/dev/stderr"
|
|
||||||
next;
|
|
||||||
}
|
|
||||||
|
|
||||||
state == "" && $1 == "<p>@@QQ@@" {
|
|
||||||
qqn++;
|
|
||||||
qqlineno = NR;
|
|
||||||
haveqq = 1;
|
|
||||||
state = "qq";
|
|
||||||
print "<p><a name=\"Quick Quiz " qqn "\"><b>Quick Quiz " qqn "</b>:</a>"
|
|
||||||
next;
|
|
||||||
}
|
|
||||||
|
|
||||||
state == "qq" && $1 != "<p>@@QQA@@" {
|
|
||||||
qq[qqn] = qq[qqn] $0 "\n";
|
|
||||||
print $0
|
|
||||||
if ($0 ~ /^<p>@@QQ/)
|
|
||||||
print "Bad Quick Quiz command: " NR ". (expected <p>@@QQA@@)" > "/dev/stderr"
|
|
||||||
next;
|
|
||||||
}
|
|
||||||
|
|
||||||
state == "qq" && $1 == "<p>@@QQA@@" {
|
|
||||||
state = "qqa";
|
|
||||||
print "<br><a href=\"#qq" qqn "answer\">Answer</a>"
|
|
||||||
next;
|
|
||||||
}
|
|
||||||
|
|
||||||
state == "qqa" && $1 != "<p>@@QQE@@" {
|
|
||||||
qqa[qqn] = qqa[qqn] $0 "\n";
|
|
||||||
if ($0 ~ /^<p>@@QQ/)
|
|
||||||
print "Bad Quick Quiz command: " NR " (expected <p>@@QQE@@)." > "/dev/stderr"
|
|
||||||
next;
|
|
||||||
}
|
|
||||||
|
|
||||||
state == "qqa" && $1 == "<p>@@QQE@@" {
|
|
||||||
state = "";
|
|
||||||
next;
|
|
||||||
}
|
|
||||||
|
|
||||||
state == "" && $1 == "<p>@@QQAL@@" {
|
|
||||||
haveqq = "";
|
|
||||||
print "<h3><a name=\"Answers to Quick Quizzes\">"
|
|
||||||
print "Answers to Quick Quizzes</a></h3>"
|
|
||||||
print "";
|
|
||||||
for (i = 1; i <= qqn; i++) {
|
|
||||||
print "<a name=\"qq" i "answer\"></a>"
|
|
||||||
print "<p><b>Quick Quiz " i "</b>:"
|
|
||||||
print qq[i];
|
|
||||||
print "";
|
|
||||||
print "</p><p><b>Answer</b>:"
|
|
||||||
print qqa[i];
|
|
||||||
print "";
|
|
||||||
print "</p><p><a href=\"#Quick%20Quiz%20" i "\"><b>Back to Quick Quiz " i "</b>.</a>"
|
|
||||||
print "";
|
|
||||||
}
|
|
||||||
next;
|
|
||||||
}
|
|
||||||
|
|
||||||
END {
|
|
||||||
if (state != "")
|
|
||||||
print "Unterminated Quick Quiz: " qqlineno "." > "/dev/stderr"
|
|
||||||
else if (haveqq)
|
|
||||||
print "Missing \"<p>@@QQAL@@\", no Quick Quiz." > "/dev/stderr"
|
|
||||||
}'
|
|
@ -237,17 +237,17 @@ o "ktl" is the low-order 16 bits (in hexadecimal) of the count of
|
|||||||
|
|
||||||
The output of "cat rcu/rcu_preempt/rcuexp" looks as follows:
|
The output of "cat rcu/rcu_preempt/rcuexp" looks as follows:
|
||||||
|
|
||||||
s=21872 wd0=0 wd1=0 wd2=0 wd3=5 n=0 enq=0 sc=21872
|
s=21872 wd1=0 wd2=0 wd3=5 n=0 enq=0 sc=21872
|
||||||
|
|
||||||
These fields are as follows:
|
These fields are as follows:
|
||||||
|
|
||||||
o "s" is the sequence number, with an odd number indicating that
|
o "s" is the sequence number, with an odd number indicating that
|
||||||
an expedited grace period is in progress.
|
an expedited grace period is in progress.
|
||||||
|
|
||||||
o "wd0", "wd1", "wd2", and "wd3" are the number of times that an
|
o "wd1", "wd2", and "wd3" are the number of times that an attempt
|
||||||
attempt to start an expedited grace period found that someone
|
to start an expedited grace period found that someone else had
|
||||||
else had completed an expedited grace period that satisfies the
|
completed an expedited grace period that satisfies the attempted
|
||||||
attempted request. "Our work is done."
|
request. "Our work is done."
|
||||||
|
|
||||||
o "n" is number of times that a concurrent CPU-hotplug operation
|
o "n" is number of times that a concurrent CPU-hotplug operation
|
||||||
forced a fallback to a normal grace period.
|
forced a fallback to a normal grace period.
|
||||||
|
@ -681,22 +681,30 @@ Although RCU can be used in many different ways, a very common use of
|
|||||||
RCU is analogous to reader-writer locking. The following unified
|
RCU is analogous to reader-writer locking. The following unified
|
||||||
diff shows how closely related RCU and reader-writer locking can be.
|
diff shows how closely related RCU and reader-writer locking can be.
|
||||||
|
|
||||||
|
@@ -5,5 +5,5 @@ struct el {
|
||||||
|
int data;
|
||||||
|
/* Other data fields */
|
||||||
|
};
|
||||||
|
-rwlock_t listmutex;
|
||||||
|
+spinlock_t listmutex;
|
||||||
|
struct el head;
|
||||||
|
|
||||||
@@ -13,15 +14,15 @@
|
@@ -13,15 +14,15 @@
|
||||||
struct list_head *lp;
|
struct list_head *lp;
|
||||||
struct el *p;
|
struct el *p;
|
||||||
|
|
||||||
- read_lock();
|
- read_lock(&listmutex);
|
||||||
- list_for_each_entry(p, head, lp) {
|
- list_for_each_entry(p, head, lp) {
|
||||||
+ rcu_read_lock();
|
+ rcu_read_lock();
|
||||||
+ list_for_each_entry_rcu(p, head, lp) {
|
+ list_for_each_entry_rcu(p, head, lp) {
|
||||||
if (p->key == key) {
|
if (p->key == key) {
|
||||||
*result = p->data;
|
*result = p->data;
|
||||||
- read_unlock();
|
- read_unlock(&listmutex);
|
||||||
+ rcu_read_unlock();
|
+ rcu_read_unlock();
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
- read_unlock();
|
- read_unlock(&listmutex);
|
||||||
+ rcu_read_unlock();
|
+ rcu_read_unlock();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -732,7 +740,7 @@ Or, for those who prefer a side-by-side listing:
|
|||||||
5 int data; 5 int data;
|
5 int data; 5 int data;
|
||||||
6 /* Other data fields */ 6 /* Other data fields */
|
6 /* Other data fields */ 6 /* Other data fields */
|
||||||
7 }; 7 };
|
7 }; 7 };
|
||||||
8 spinlock_t listmutex; 8 spinlock_t listmutex;
|
8 rwlock_t listmutex; 8 spinlock_t listmutex;
|
||||||
9 struct el head; 9 struct el head;
|
9 struct el head; 9 struct el head;
|
||||||
|
|
||||||
1 int search(long key, int *result) 1 int search(long key, int *result)
|
1 int search(long key, int *result) 1 int search(long key, int *result)
|
||||||
@ -740,15 +748,15 @@ Or, for those who prefer a side-by-side listing:
|
|||||||
3 struct list_head *lp; 3 struct list_head *lp;
|
3 struct list_head *lp; 3 struct list_head *lp;
|
||||||
4 struct el *p; 4 struct el *p;
|
4 struct el *p; 4 struct el *p;
|
||||||
5 5
|
5 5
|
||||||
6 read_lock(); 6 rcu_read_lock();
|
6 read_lock(&listmutex); 6 rcu_read_lock();
|
||||||
7 list_for_each_entry(p, head, lp) { 7 list_for_each_entry_rcu(p, head, lp) {
|
7 list_for_each_entry(p, head, lp) { 7 list_for_each_entry_rcu(p, head, lp) {
|
||||||
8 if (p->key == key) { 8 if (p->key == key) {
|
8 if (p->key == key) { 8 if (p->key == key) {
|
||||||
9 *result = p->data; 9 *result = p->data;
|
9 *result = p->data; 9 *result = p->data;
|
||||||
10 read_unlock(); 10 rcu_read_unlock();
|
10 read_unlock(&listmutex); 10 rcu_read_unlock();
|
||||||
11 return 1; 11 return 1;
|
11 return 1; 11 return 1;
|
||||||
12 } 12 }
|
12 } 12 }
|
||||||
13 } 13 }
|
13 } 13 }
|
||||||
14 read_unlock(); 14 rcu_read_unlock();
|
14 read_unlock(&listmutex); 14 rcu_read_unlock();
|
||||||
15 return 0; 15 return 0;
|
15 return 0; 15 return 0;
|
||||||
16 } 16 }
|
16 } 16 }
|
||||||
|
|
||||||
|
@ -3284,6 +3284,44 @@ bytes respectively. Such letter suffixes can also be entirely omitted.
|
|||||||
Lazy RCU callbacks are those which RCU can
|
Lazy RCU callbacks are those which RCU can
|
||||||
prove do nothing more than free memory.
|
prove do nothing more than free memory.
|
||||||
|
|
||||||
|
rcuperf.gp_exp= [KNL]
|
||||||
|
Measure performance of expedited synchronous
|
||||||
|
grace-period primitives.
|
||||||
|
|
||||||
|
rcuperf.holdoff= [KNL]
|
||||||
|
Set test-start holdoff period. The purpose of
|
||||||
|
this parameter is to delay the start of the
|
||||||
|
test until boot completes in order to avoid
|
||||||
|
interference.
|
||||||
|
|
||||||
|
rcuperf.nreaders= [KNL]
|
||||||
|
Set number of RCU readers. The value -1 selects
|
||||||
|
N, where N is the number of CPUs. A value
|
||||||
|
"n" less than -1 selects N-n+1, where N is again
|
||||||
|
the number of CPUs. For example, -2 selects N
|
||||||
|
(the number of CPUs), -3 selects N+1, and so on.
|
||||||
|
A value of "n" less than or equal to -N selects
|
||||||
|
a single reader.
|
||||||
|
|
||||||
|
rcuperf.nwriters= [KNL]
|
||||||
|
Set number of RCU writers. The values operate
|
||||||
|
the same as for rcuperf.nreaders.
|
||||||
|
N, where N is the number of CPUs
|
||||||
|
|
||||||
|
rcuperf.perf_runnable= [BOOT]
|
||||||
|
Start rcuperf running at boot time.
|
||||||
|
|
||||||
|
rcuperf.shutdown= [KNL]
|
||||||
|
Shut the system down after performance tests
|
||||||
|
complete. This is useful for hands-off automated
|
||||||
|
testing.
|
||||||
|
|
||||||
|
rcuperf.perf_type= [KNL]
|
||||||
|
Specify the RCU implementation to test.
|
||||||
|
|
||||||
|
rcuperf.verbose= [KNL]
|
||||||
|
Enable additional printk() statements.
|
||||||
|
|
||||||
rcutorture.cbflood_inter_holdoff= [KNL]
|
rcutorture.cbflood_inter_holdoff= [KNL]
|
||||||
Set holdoff time (jiffies) between successive
|
Set holdoff time (jiffies) between successive
|
||||||
callback-flood tests.
|
callback-flood tests.
|
||||||
|
@ -508,14 +508,7 @@ int rcu_read_lock_bh_held(void);
|
|||||||
* CONFIG_DEBUG_LOCK_ALLOC, this assumes we are in an RCU-sched read-side
|
* CONFIG_DEBUG_LOCK_ALLOC, this assumes we are in an RCU-sched read-side
|
||||||
* critical section unless it can prove otherwise.
|
* critical section unless it can prove otherwise.
|
||||||
*/
|
*/
|
||||||
#ifdef CONFIG_PREEMPT_COUNT
|
|
||||||
int rcu_read_lock_sched_held(void);
|
int rcu_read_lock_sched_held(void);
|
||||||
#else /* #ifdef CONFIG_PREEMPT_COUNT */
|
|
||||||
static inline int rcu_read_lock_sched_held(void)
|
|
||||||
{
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
#endif /* #else #ifdef CONFIG_PREEMPT_COUNT */
|
|
||||||
|
|
||||||
#else /* #ifdef CONFIG_DEBUG_LOCK_ALLOC */
|
#else /* #ifdef CONFIG_DEBUG_LOCK_ALLOC */
|
||||||
|
|
||||||
@ -532,18 +525,10 @@ static inline int rcu_read_lock_bh_held(void)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_PREEMPT_COUNT
|
|
||||||
static inline int rcu_read_lock_sched_held(void)
|
static inline int rcu_read_lock_sched_held(void)
|
||||||
{
|
{
|
||||||
return preempt_count() != 0 || irqs_disabled();
|
return !preemptible();
|
||||||
}
|
}
|
||||||
#else /* #ifdef CONFIG_PREEMPT_COUNT */
|
|
||||||
static inline int rcu_read_lock_sched_held(void)
|
|
||||||
{
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
#endif /* #else #ifdef CONFIG_PREEMPT_COUNT */
|
|
||||||
|
|
||||||
#endif /* #else #ifdef CONFIG_DEBUG_LOCK_ALLOC */
|
#endif /* #else #ifdef CONFIG_DEBUG_LOCK_ALLOC */
|
||||||
|
|
||||||
#ifdef CONFIG_PROVE_RCU
|
#ifdef CONFIG_PROVE_RCU
|
||||||
@ -1144,4 +1129,17 @@ static inline void rcu_sysidle_force_exit(void)
|
|||||||
#endif /* #else #ifdef CONFIG_NO_HZ_FULL_SYSIDLE */
|
#endif /* #else #ifdef CONFIG_NO_HZ_FULL_SYSIDLE */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Dump the ftrace buffer, but only one time per callsite per boot.
|
||||||
|
*/
|
||||||
|
#define rcu_ftrace_dump(oops_dump_mode) \
|
||||||
|
do { \
|
||||||
|
static atomic_t ___rfd_beenhere = ATOMIC_INIT(0); \
|
||||||
|
\
|
||||||
|
if (!atomic_read(&___rfd_beenhere) && \
|
||||||
|
!atomic_xchg(&___rfd_beenhere, 1)) \
|
||||||
|
ftrace_dump(oops_dump_mode); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
|
||||||
#endif /* __LINUX_RCUPDATE_H */
|
#endif /* __LINUX_RCUPDATE_H */
|
||||||
|
@ -149,6 +149,22 @@ static inline unsigned long rcu_batches_completed_sched(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return the number of expedited grace periods completed.
|
||||||
|
*/
|
||||||
|
static inline unsigned long rcu_exp_batches_completed(void)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return the number of expedited sched grace periods completed.
|
||||||
|
*/
|
||||||
|
static inline unsigned long rcu_exp_batches_completed_sched(void)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static inline void rcu_force_quiescent_state(void)
|
static inline void rcu_force_quiescent_state(void)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -87,6 +87,8 @@ unsigned long rcu_batches_started_sched(void);
|
|||||||
unsigned long rcu_batches_completed(void);
|
unsigned long rcu_batches_completed(void);
|
||||||
unsigned long rcu_batches_completed_bh(void);
|
unsigned long rcu_batches_completed_bh(void);
|
||||||
unsigned long rcu_batches_completed_sched(void);
|
unsigned long rcu_batches_completed_sched(void);
|
||||||
|
unsigned long rcu_exp_batches_completed(void);
|
||||||
|
unsigned long rcu_exp_batches_completed_sched(void);
|
||||||
void show_rcu_gp_kthreads(void);
|
void show_rcu_gp_kthreads(void);
|
||||||
|
|
||||||
void rcu_force_quiescent_state(void);
|
void rcu_force_quiescent_state(void);
|
||||||
|
@ -171,6 +171,77 @@ TRACE_EVENT(rcu_grace_period_init,
|
|||||||
__entry->grplo, __entry->grphi, __entry->qsmask)
|
__entry->grplo, __entry->grphi, __entry->qsmask)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Tracepoint for expedited grace-period events. Takes a string identifying
|
||||||
|
* the RCU flavor, the expedited grace-period sequence number, and a string
|
||||||
|
* identifying the grace-period-related event as follows:
|
||||||
|
*
|
||||||
|
* "snap": Captured snapshot of expedited grace period sequence number.
|
||||||
|
* "start": Started a real expedited grace period.
|
||||||
|
* "end": Ended a real expedited grace period.
|
||||||
|
* "endwake": Woke piggybackers up.
|
||||||
|
* "done": Someone else did the expedited grace period for us.
|
||||||
|
*/
|
||||||
|
TRACE_EVENT(rcu_exp_grace_period,
|
||||||
|
|
||||||
|
TP_PROTO(const char *rcuname, unsigned long gpseq, const char *gpevent),
|
||||||
|
|
||||||
|
TP_ARGS(rcuname, gpseq, gpevent),
|
||||||
|
|
||||||
|
TP_STRUCT__entry(
|
||||||
|
__field(const char *, rcuname)
|
||||||
|
__field(unsigned long, gpseq)
|
||||||
|
__field(const char *, gpevent)
|
||||||
|
),
|
||||||
|
|
||||||
|
TP_fast_assign(
|
||||||
|
__entry->rcuname = rcuname;
|
||||||
|
__entry->gpseq = gpseq;
|
||||||
|
__entry->gpevent = gpevent;
|
||||||
|
),
|
||||||
|
|
||||||
|
TP_printk("%s %lu %s",
|
||||||
|
__entry->rcuname, __entry->gpseq, __entry->gpevent)
|
||||||
|
);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Tracepoint for expedited grace-period funnel-locking events. Takes a
|
||||||
|
* string identifying the RCU flavor, an integer identifying the rcu_node
|
||||||
|
* combining-tree level, another pair of integers identifying the lowest-
|
||||||
|
* and highest-numbered CPU associated with the current rcu_node structure,
|
||||||
|
* and a string. identifying the grace-period-related event as follows:
|
||||||
|
*
|
||||||
|
* "nxtlvl": Advance to next level of rcu_node funnel
|
||||||
|
* "wait": Wait for someone else to do expedited GP
|
||||||
|
*/
|
||||||
|
TRACE_EVENT(rcu_exp_funnel_lock,
|
||||||
|
|
||||||
|
TP_PROTO(const char *rcuname, u8 level, int grplo, int grphi,
|
||||||
|
const char *gpevent),
|
||||||
|
|
||||||
|
TP_ARGS(rcuname, level, grplo, grphi, gpevent),
|
||||||
|
|
||||||
|
TP_STRUCT__entry(
|
||||||
|
__field(const char *, rcuname)
|
||||||
|
__field(u8, level)
|
||||||
|
__field(int, grplo)
|
||||||
|
__field(int, grphi)
|
||||||
|
__field(const char *, gpevent)
|
||||||
|
),
|
||||||
|
|
||||||
|
TP_fast_assign(
|
||||||
|
__entry->rcuname = rcuname;
|
||||||
|
__entry->level = level;
|
||||||
|
__entry->grplo = grplo;
|
||||||
|
__entry->grphi = grphi;
|
||||||
|
__entry->gpevent = gpevent;
|
||||||
|
),
|
||||||
|
|
||||||
|
TP_printk("%s %d %d %d %s",
|
||||||
|
__entry->rcuname, __entry->level, __entry->grplo,
|
||||||
|
__entry->grphi, __entry->gpevent)
|
||||||
|
);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Tracepoint for RCU no-CBs CPU callback handoffs. This event is intended
|
* Tracepoint for RCU no-CBs CPU callback handoffs. This event is intended
|
||||||
* to assist debugging of these handoffs.
|
* to assist debugging of these handoffs.
|
||||||
@ -704,11 +775,15 @@ TRACE_EVENT(rcu_barrier,
|
|||||||
#else /* #ifdef CONFIG_RCU_TRACE */
|
#else /* #ifdef CONFIG_RCU_TRACE */
|
||||||
|
|
||||||
#define trace_rcu_grace_period(rcuname, gpnum, gpevent) do { } while (0)
|
#define trace_rcu_grace_period(rcuname, gpnum, gpevent) do { } while (0)
|
||||||
#define trace_rcu_grace_period_init(rcuname, gpnum, level, grplo, grphi, \
|
|
||||||
qsmask) do { } while (0)
|
|
||||||
#define trace_rcu_future_grace_period(rcuname, gpnum, completed, c, \
|
#define trace_rcu_future_grace_period(rcuname, gpnum, completed, c, \
|
||||||
level, grplo, grphi, event) \
|
level, grplo, grphi, event) \
|
||||||
do { } while (0)
|
do { } while (0)
|
||||||
|
#define trace_rcu_grace_period_init(rcuname, gpnum, level, grplo, grphi, \
|
||||||
|
qsmask) do { } while (0)
|
||||||
|
#define trace_rcu_exp_grace_period(rcuname, gqseq, gpevent) \
|
||||||
|
do { } while (0)
|
||||||
|
#define trace_rcu_exp_funnel_lock(rcuname, level, grplo, grphi, gpevent) \
|
||||||
|
do { } while (0)
|
||||||
#define trace_rcu_nocb_wake(rcuname, cpu, reason) do { } while (0)
|
#define trace_rcu_nocb_wake(rcuname, cpu, reason) do { } while (0)
|
||||||
#define trace_rcu_preempt_task(rcuname, pid, gpnum) do { } while (0)
|
#define trace_rcu_preempt_task(rcuname, pid, gpnum) do { } while (0)
|
||||||
#define trace_rcu_unlock_preempted_task(rcuname, gpnum, pid) do { } while (0)
|
#define trace_rcu_unlock_preempted_task(rcuname, gpnum, pid) do { } while (0)
|
||||||
|
@ -5,6 +5,7 @@ KCOV_INSTRUMENT := n
|
|||||||
obj-y += update.o sync.o
|
obj-y += update.o sync.o
|
||||||
obj-$(CONFIG_SRCU) += srcu.o
|
obj-$(CONFIG_SRCU) += srcu.o
|
||||||
obj-$(CONFIG_RCU_TORTURE_TEST) += rcutorture.o
|
obj-$(CONFIG_RCU_TORTURE_TEST) += rcutorture.o
|
||||||
|
obj-$(CONFIG_RCU_PERF_TEST) += rcuperf.o
|
||||||
obj-$(CONFIG_TREE_RCU) += tree.o
|
obj-$(CONFIG_TREE_RCU) += tree.o
|
||||||
obj-$(CONFIG_PREEMPT_RCU) += tree.o
|
obj-$(CONFIG_PREEMPT_RCU) += tree.o
|
||||||
obj-$(CONFIG_TREE_RCU_TRACE) += tree_trace.o
|
obj-$(CONFIG_TREE_RCU_TRACE) += tree_trace.o
|
||||||
|
655
kernel/rcu/rcuperf.c
Normal file
@ -0,0 +1,655 @@
|
|||||||
|
/*
|
||||||
|
* Read-Copy Update module-based performance-test facility
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, you can access it online at
|
||||||
|
* http://www.gnu.org/licenses/gpl-2.0.html.
|
||||||
|
*
|
||||||
|
* Copyright (C) IBM Corporation, 2015
|
||||||
|
*
|
||||||
|
* Authors: Paul E. McKenney <paulmck@us.ibm.com>
|
||||||
|
*/
|
||||||
|
#include <linux/types.h>
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/init.h>
|
||||||
|
#include <linux/module.h>
|
||||||
|
#include <linux/kthread.h>
|
||||||
|
#include <linux/err.h>
|
||||||
|
#include <linux/spinlock.h>
|
||||||
|
#include <linux/smp.h>
|
||||||
|
#include <linux/rcupdate.h>
|
||||||
|
#include <linux/interrupt.h>
|
||||||
|
#include <linux/sched.h>
|
||||||
|
#include <linux/atomic.h>
|
||||||
|
#include <linux/bitops.h>
|
||||||
|
#include <linux/completion.h>
|
||||||
|
#include <linux/moduleparam.h>
|
||||||
|
#include <linux/percpu.h>
|
||||||
|
#include <linux/notifier.h>
|
||||||
|
#include <linux/reboot.h>
|
||||||
|
#include <linux/freezer.h>
|
||||||
|
#include <linux/cpu.h>
|
||||||
|
#include <linux/delay.h>
|
||||||
|
#include <linux/stat.h>
|
||||||
|
#include <linux/srcu.h>
|
||||||
|
#include <linux/slab.h>
|
||||||
|
#include <asm/byteorder.h>
|
||||||
|
#include <linux/torture.h>
|
||||||
|
#include <linux/vmalloc.h>
|
||||||
|
|
||||||
|
MODULE_LICENSE("GPL");
|
||||||
|
MODULE_AUTHOR("Paul E. McKenney <paulmck@linux.vnet.ibm.com>");
|
||||||
|
|
||||||
|
#define PERF_FLAG "-perf:"
|
||||||
|
#define PERFOUT_STRING(s) \
|
||||||
|
pr_alert("%s" PERF_FLAG s "\n", perf_type)
|
||||||
|
#define VERBOSE_PERFOUT_STRING(s) \
|
||||||
|
do { if (verbose) pr_alert("%s" PERF_FLAG " %s\n", perf_type, s); } while (0)
|
||||||
|
#define VERBOSE_PERFOUT_ERRSTRING(s) \
|
||||||
|
do { if (verbose) pr_alert("%s" PERF_FLAG "!!! %s\n", perf_type, s); } while (0)
|
||||||
|
|
||||||
|
torture_param(bool, gp_exp, true, "Use expedited GP wait primitives");
|
||||||
|
torture_param(int, holdoff, 10, "Holdoff time before test start (s)");
|
||||||
|
torture_param(int, nreaders, -1, "Number of RCU reader threads");
|
||||||
|
torture_param(int, nwriters, -1, "Number of RCU updater threads");
|
||||||
|
torture_param(bool, shutdown, false, "Shutdown at end of performance tests.");
|
||||||
|
torture_param(bool, verbose, true, "Enable verbose debugging printk()s");
|
||||||
|
|
||||||
|
static char *perf_type = "rcu";
|
||||||
|
module_param(perf_type, charp, 0444);
|
||||||
|
MODULE_PARM_DESC(perf_type, "Type of RCU to performance-test (rcu, rcu_bh, ...)");
|
||||||
|
|
||||||
|
static int nrealreaders;
|
||||||
|
static int nrealwriters;
|
||||||
|
static struct task_struct **writer_tasks;
|
||||||
|
static struct task_struct **reader_tasks;
|
||||||
|
static struct task_struct *shutdown_task;
|
||||||
|
|
||||||
|
static u64 **writer_durations;
|
||||||
|
static int *writer_n_durations;
|
||||||
|
static atomic_t n_rcu_perf_reader_started;
|
||||||
|
static atomic_t n_rcu_perf_writer_started;
|
||||||
|
static atomic_t n_rcu_perf_writer_finished;
|
||||||
|
static wait_queue_head_t shutdown_wq;
|
||||||
|
static u64 t_rcu_perf_writer_started;
|
||||||
|
static u64 t_rcu_perf_writer_finished;
|
||||||
|
static unsigned long b_rcu_perf_writer_started;
|
||||||
|
static unsigned long b_rcu_perf_writer_finished;
|
||||||
|
|
||||||
|
static int rcu_perf_writer_state;
|
||||||
|
#define RTWS_INIT 0
|
||||||
|
#define RTWS_EXP_SYNC 1
|
||||||
|
#define RTWS_SYNC 2
|
||||||
|
#define RTWS_IDLE 2
|
||||||
|
#define RTWS_STOPPING 3
|
||||||
|
|
||||||
|
#define MAX_MEAS 10000
|
||||||
|
#define MIN_MEAS 100
|
||||||
|
|
||||||
|
#if defined(MODULE) || defined(CONFIG_RCU_PERF_TEST_RUNNABLE)
|
||||||
|
#define RCUPERF_RUNNABLE_INIT 1
|
||||||
|
#else
|
||||||
|
#define RCUPERF_RUNNABLE_INIT 0
|
||||||
|
#endif
|
||||||
|
static int perf_runnable = RCUPERF_RUNNABLE_INIT;
|
||||||
|
module_param(perf_runnable, int, 0444);
|
||||||
|
MODULE_PARM_DESC(perf_runnable, "Start rcuperf at boot");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Operations vector for selecting different types of tests.
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct rcu_perf_ops {
|
||||||
|
int ptype;
|
||||||
|
void (*init)(void);
|
||||||
|
void (*cleanup)(void);
|
||||||
|
int (*readlock)(void);
|
||||||
|
void (*readunlock)(int idx);
|
||||||
|
unsigned long (*started)(void);
|
||||||
|
unsigned long (*completed)(void);
|
||||||
|
unsigned long (*exp_completed)(void);
|
||||||
|
void (*sync)(void);
|
||||||
|
void (*exp_sync)(void);
|
||||||
|
const char *name;
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct rcu_perf_ops *cur_ops;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Definitions for rcu perf testing.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static int rcu_perf_read_lock(void) __acquires(RCU)
|
||||||
|
{
|
||||||
|
rcu_read_lock();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void rcu_perf_read_unlock(int idx) __releases(RCU)
|
||||||
|
{
|
||||||
|
rcu_read_unlock();
|
||||||
|
}
|
||||||
|
|
||||||
|
static unsigned long __maybe_unused rcu_no_completed(void)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void rcu_sync_perf_init(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct rcu_perf_ops rcu_ops = {
|
||||||
|
.ptype = RCU_FLAVOR,
|
||||||
|
.init = rcu_sync_perf_init,
|
||||||
|
.readlock = rcu_perf_read_lock,
|
||||||
|
.readunlock = rcu_perf_read_unlock,
|
||||||
|
.started = rcu_batches_started,
|
||||||
|
.completed = rcu_batches_completed,
|
||||||
|
.exp_completed = rcu_exp_batches_completed,
|
||||||
|
.sync = synchronize_rcu,
|
||||||
|
.exp_sync = synchronize_rcu_expedited,
|
||||||
|
.name = "rcu"
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Definitions for rcu_bh perf testing.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static int rcu_bh_perf_read_lock(void) __acquires(RCU_BH)
|
||||||
|
{
|
||||||
|
rcu_read_lock_bh();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void rcu_bh_perf_read_unlock(int idx) __releases(RCU_BH)
|
||||||
|
{
|
||||||
|
rcu_read_unlock_bh();
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct rcu_perf_ops rcu_bh_ops = {
|
||||||
|
.ptype = RCU_BH_FLAVOR,
|
||||||
|
.init = rcu_sync_perf_init,
|
||||||
|
.readlock = rcu_bh_perf_read_lock,
|
||||||
|
.readunlock = rcu_bh_perf_read_unlock,
|
||||||
|
.started = rcu_batches_started_bh,
|
||||||
|
.completed = rcu_batches_completed_bh,
|
||||||
|
.exp_completed = rcu_exp_batches_completed_sched,
|
||||||
|
.sync = synchronize_rcu_bh,
|
||||||
|
.exp_sync = synchronize_rcu_bh_expedited,
|
||||||
|
.name = "rcu_bh"
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Definitions for srcu perf testing.
|
||||||
|
*/
|
||||||
|
|
||||||
|
DEFINE_STATIC_SRCU(srcu_ctl_perf);
|
||||||
|
static struct srcu_struct *srcu_ctlp = &srcu_ctl_perf;
|
||||||
|
|
||||||
|
static int srcu_perf_read_lock(void) __acquires(srcu_ctlp)
|
||||||
|
{
|
||||||
|
return srcu_read_lock(srcu_ctlp);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void srcu_perf_read_unlock(int idx) __releases(srcu_ctlp)
|
||||||
|
{
|
||||||
|
srcu_read_unlock(srcu_ctlp, idx);
|
||||||
|
}
|
||||||
|
|
||||||
|
static unsigned long srcu_perf_completed(void)
|
||||||
|
{
|
||||||
|
return srcu_batches_completed(srcu_ctlp);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void srcu_perf_synchronize(void)
|
||||||
|
{
|
||||||
|
synchronize_srcu(srcu_ctlp);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void srcu_perf_synchronize_expedited(void)
|
||||||
|
{
|
||||||
|
synchronize_srcu_expedited(srcu_ctlp);
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct rcu_perf_ops srcu_ops = {
|
||||||
|
.ptype = SRCU_FLAVOR,
|
||||||
|
.init = rcu_sync_perf_init,
|
||||||
|
.readlock = srcu_perf_read_lock,
|
||||||
|
.readunlock = srcu_perf_read_unlock,
|
||||||
|
.started = NULL,
|
||||||
|
.completed = srcu_perf_completed,
|
||||||
|
.exp_completed = srcu_perf_completed,
|
||||||
|
.sync = srcu_perf_synchronize,
|
||||||
|
.exp_sync = srcu_perf_synchronize_expedited,
|
||||||
|
.name = "srcu"
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Definitions for sched perf testing.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static int sched_perf_read_lock(void)
|
||||||
|
{
|
||||||
|
preempt_disable();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void sched_perf_read_unlock(int idx)
|
||||||
|
{
|
||||||
|
preempt_enable();
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct rcu_perf_ops sched_ops = {
|
||||||
|
.ptype = RCU_SCHED_FLAVOR,
|
||||||
|
.init = rcu_sync_perf_init,
|
||||||
|
.readlock = sched_perf_read_lock,
|
||||||
|
.readunlock = sched_perf_read_unlock,
|
||||||
|
.started = rcu_batches_started_sched,
|
||||||
|
.completed = rcu_batches_completed_sched,
|
||||||
|
.exp_completed = rcu_exp_batches_completed_sched,
|
||||||
|
.sync = synchronize_sched,
|
||||||
|
.exp_sync = synchronize_sched_expedited,
|
||||||
|
.name = "sched"
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef CONFIG_TASKS_RCU
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Definitions for RCU-tasks perf testing.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static int tasks_perf_read_lock(void)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void tasks_perf_read_unlock(int idx)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct rcu_perf_ops tasks_ops = {
|
||||||
|
.ptype = RCU_TASKS_FLAVOR,
|
||||||
|
.init = rcu_sync_perf_init,
|
||||||
|
.readlock = tasks_perf_read_lock,
|
||||||
|
.readunlock = tasks_perf_read_unlock,
|
||||||
|
.started = rcu_no_completed,
|
||||||
|
.completed = rcu_no_completed,
|
||||||
|
.sync = synchronize_rcu_tasks,
|
||||||
|
.exp_sync = synchronize_rcu_tasks,
|
||||||
|
.name = "tasks"
|
||||||
|
};
|
||||||
|
|
||||||
|
#define RCUPERF_TASKS_OPS &tasks_ops,
|
||||||
|
|
||||||
|
static bool __maybe_unused torturing_tasks(void)
|
||||||
|
{
|
||||||
|
return cur_ops == &tasks_ops;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else /* #ifdef CONFIG_TASKS_RCU */
|
||||||
|
|
||||||
|
#define RCUPERF_TASKS_OPS
|
||||||
|
|
||||||
|
static bool __maybe_unused torturing_tasks(void)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* #else #ifdef CONFIG_TASKS_RCU */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If performance tests complete, wait for shutdown to commence.
|
||||||
|
*/
|
||||||
|
static void rcu_perf_wait_shutdown(void)
|
||||||
|
{
|
||||||
|
cond_resched_rcu_qs();
|
||||||
|
if (atomic_read(&n_rcu_perf_writer_finished) < nrealwriters)
|
||||||
|
return;
|
||||||
|
while (!torture_must_stop())
|
||||||
|
schedule_timeout_uninterruptible(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* RCU perf reader kthread. Repeatedly does empty RCU read-side
|
||||||
|
* critical section, minimizing update-side interference.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
rcu_perf_reader(void *arg)
|
||||||
|
{
|
||||||
|
unsigned long flags;
|
||||||
|
int idx;
|
||||||
|
long me = (long)arg;
|
||||||
|
|
||||||
|
VERBOSE_PERFOUT_STRING("rcu_perf_reader task started");
|
||||||
|
set_cpus_allowed_ptr(current, cpumask_of(me % nr_cpu_ids));
|
||||||
|
set_user_nice(current, MAX_NICE);
|
||||||
|
atomic_inc(&n_rcu_perf_reader_started);
|
||||||
|
|
||||||
|
do {
|
||||||
|
local_irq_save(flags);
|
||||||
|
idx = cur_ops->readlock();
|
||||||
|
cur_ops->readunlock(idx);
|
||||||
|
local_irq_restore(flags);
|
||||||
|
rcu_perf_wait_shutdown();
|
||||||
|
} while (!torture_must_stop());
|
||||||
|
torture_kthread_stopping("rcu_perf_reader");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* RCU perf writer kthread. Repeatedly does a grace period.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
rcu_perf_writer(void *arg)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
int i_max;
|
||||||
|
long me = (long)arg;
|
||||||
|
struct sched_param sp;
|
||||||
|
bool started = false, done = false, alldone = false;
|
||||||
|
u64 t;
|
||||||
|
u64 *wdp;
|
||||||
|
u64 *wdpp = writer_durations[me];
|
||||||
|
|
||||||
|
VERBOSE_PERFOUT_STRING("rcu_perf_writer task started");
|
||||||
|
WARN_ON(rcu_gp_is_expedited() && !rcu_gp_is_normal() && !gp_exp);
|
||||||
|
WARN_ON(rcu_gp_is_normal() && gp_exp);
|
||||||
|
WARN_ON(!wdpp);
|
||||||
|
set_cpus_allowed_ptr(current, cpumask_of(me % nr_cpu_ids));
|
||||||
|
sp.sched_priority = 1;
|
||||||
|
sched_setscheduler_nocheck(current, SCHED_FIFO, &sp);
|
||||||
|
|
||||||
|
if (holdoff)
|
||||||
|
schedule_timeout_uninterruptible(holdoff * HZ);
|
||||||
|
|
||||||
|
t = ktime_get_mono_fast_ns();
|
||||||
|
if (atomic_inc_return(&n_rcu_perf_writer_started) >= nrealwriters) {
|
||||||
|
t_rcu_perf_writer_started = t;
|
||||||
|
if (gp_exp) {
|
||||||
|
b_rcu_perf_writer_started =
|
||||||
|
cur_ops->exp_completed() / 2;
|
||||||
|
} else {
|
||||||
|
b_rcu_perf_writer_started =
|
||||||
|
cur_ops->completed();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
do {
|
||||||
|
wdp = &wdpp[i];
|
||||||
|
*wdp = ktime_get_mono_fast_ns();
|
||||||
|
if (gp_exp) {
|
||||||
|
rcu_perf_writer_state = RTWS_EXP_SYNC;
|
||||||
|
cur_ops->exp_sync();
|
||||||
|
} else {
|
||||||
|
rcu_perf_writer_state = RTWS_SYNC;
|
||||||
|
cur_ops->sync();
|
||||||
|
}
|
||||||
|
rcu_perf_writer_state = RTWS_IDLE;
|
||||||
|
t = ktime_get_mono_fast_ns();
|
||||||
|
*wdp = t - *wdp;
|
||||||
|
i_max = i;
|
||||||
|
if (!started &&
|
||||||
|
atomic_read(&n_rcu_perf_writer_started) >= nrealwriters)
|
||||||
|
started = true;
|
||||||
|
if (!done && i >= MIN_MEAS) {
|
||||||
|
done = true;
|
||||||
|
sp.sched_priority = 0;
|
||||||
|
sched_setscheduler_nocheck(current,
|
||||||
|
SCHED_NORMAL, &sp);
|
||||||
|
pr_alert("%s" PERF_FLAG
|
||||||
|
"rcu_perf_writer %ld has %d measurements\n",
|
||||||
|
perf_type, me, MIN_MEAS);
|
||||||
|
if (atomic_inc_return(&n_rcu_perf_writer_finished) >=
|
||||||
|
nrealwriters) {
|
||||||
|
schedule_timeout_interruptible(10);
|
||||||
|
rcu_ftrace_dump(DUMP_ALL);
|
||||||
|
PERFOUT_STRING("Test complete");
|
||||||
|
t_rcu_perf_writer_finished = t;
|
||||||
|
if (gp_exp) {
|
||||||
|
b_rcu_perf_writer_finished =
|
||||||
|
cur_ops->exp_completed() / 2;
|
||||||
|
} else {
|
||||||
|
b_rcu_perf_writer_finished =
|
||||||
|
cur_ops->completed();
|
||||||
|
}
|
||||||
|
if (shutdown) {
|
||||||
|
smp_mb(); /* Assign before wake. */
|
||||||
|
wake_up(&shutdown_wq);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (done && !alldone &&
|
||||||
|
atomic_read(&n_rcu_perf_writer_finished) >= nrealwriters)
|
||||||
|
alldone = true;
|
||||||
|
if (started && !alldone && i < MAX_MEAS - 1)
|
||||||
|
i++;
|
||||||
|
rcu_perf_wait_shutdown();
|
||||||
|
} while (!torture_must_stop());
|
||||||
|
rcu_perf_writer_state = RTWS_STOPPING;
|
||||||
|
writer_n_durations[me] = i_max;
|
||||||
|
torture_kthread_stopping("rcu_perf_writer");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void
|
||||||
|
rcu_perf_print_module_parms(struct rcu_perf_ops *cur_ops, const char *tag)
|
||||||
|
{
|
||||||
|
pr_alert("%s" PERF_FLAG
|
||||||
|
"--- %s: nreaders=%d nwriters=%d verbose=%d shutdown=%d\n",
|
||||||
|
perf_type, tag, nrealreaders, nrealwriters, verbose, shutdown);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
rcu_perf_cleanup(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
int j;
|
||||||
|
int ngps = 0;
|
||||||
|
u64 *wdp;
|
||||||
|
u64 *wdpp;
|
||||||
|
|
||||||
|
if (torture_cleanup_begin())
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (reader_tasks) {
|
||||||
|
for (i = 0; i < nrealreaders; i++)
|
||||||
|
torture_stop_kthread(rcu_perf_reader,
|
||||||
|
reader_tasks[i]);
|
||||||
|
kfree(reader_tasks);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (writer_tasks) {
|
||||||
|
for (i = 0; i < nrealwriters; i++) {
|
||||||
|
torture_stop_kthread(rcu_perf_writer,
|
||||||
|
writer_tasks[i]);
|
||||||
|
if (!writer_n_durations)
|
||||||
|
continue;
|
||||||
|
j = writer_n_durations[i];
|
||||||
|
pr_alert("%s%s writer %d gps: %d\n",
|
||||||
|
perf_type, PERF_FLAG, i, j);
|
||||||
|
ngps += j;
|
||||||
|
}
|
||||||
|
pr_alert("%s%s start: %llu end: %llu duration: %llu gps: %d batches: %ld\n",
|
||||||
|
perf_type, PERF_FLAG,
|
||||||
|
t_rcu_perf_writer_started, t_rcu_perf_writer_finished,
|
||||||
|
t_rcu_perf_writer_finished -
|
||||||
|
t_rcu_perf_writer_started,
|
||||||
|
ngps,
|
||||||
|
b_rcu_perf_writer_finished -
|
||||||
|
b_rcu_perf_writer_started);
|
||||||
|
for (i = 0; i < nrealwriters; i++) {
|
||||||
|
if (!writer_durations)
|
||||||
|
break;
|
||||||
|
if (!writer_n_durations)
|
||||||
|
continue;
|
||||||
|
wdpp = writer_durations[i];
|
||||||
|
if (!wdpp)
|
||||||
|
continue;
|
||||||
|
for (j = 0; j <= writer_n_durations[i]; j++) {
|
||||||
|
wdp = &wdpp[j];
|
||||||
|
pr_alert("%s%s %4d writer-duration: %5d %llu\n",
|
||||||
|
perf_type, PERF_FLAG,
|
||||||
|
i, j, *wdp);
|
||||||
|
if (j % 100 == 0)
|
||||||
|
schedule_timeout_uninterruptible(1);
|
||||||
|
}
|
||||||
|
kfree(writer_durations[i]);
|
||||||
|
}
|
||||||
|
kfree(writer_tasks);
|
||||||
|
kfree(writer_durations);
|
||||||
|
kfree(writer_n_durations);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Do flavor-specific cleanup operations. */
|
||||||
|
if (cur_ops->cleanup != NULL)
|
||||||
|
cur_ops->cleanup();
|
||||||
|
|
||||||
|
torture_cleanup_end();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return the number if non-negative. If -1, the number of CPUs.
|
||||||
|
* If less than -1, that much less than the number of CPUs, but
|
||||||
|
* at least one.
|
||||||
|
*/
|
||||||
|
static int compute_real(int n)
|
||||||
|
{
|
||||||
|
int nr;
|
||||||
|
|
||||||
|
if (n >= 0) {
|
||||||
|
nr = n;
|
||||||
|
} else {
|
||||||
|
nr = num_online_cpus() + 1 + n;
|
||||||
|
if (nr <= 0)
|
||||||
|
nr = 1;
|
||||||
|
}
|
||||||
|
return nr;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* RCU perf shutdown kthread. Just waits to be awakened, then shuts
|
||||||
|
* down system.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
rcu_perf_shutdown(void *arg)
|
||||||
|
{
|
||||||
|
do {
|
||||||
|
wait_event(shutdown_wq,
|
||||||
|
atomic_read(&n_rcu_perf_writer_finished) >=
|
||||||
|
nrealwriters);
|
||||||
|
} while (atomic_read(&n_rcu_perf_writer_finished) < nrealwriters);
|
||||||
|
smp_mb(); /* Wake before output. */
|
||||||
|
rcu_perf_cleanup();
|
||||||
|
kernel_power_off();
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int __init
|
||||||
|
rcu_perf_init(void)
|
||||||
|
{
|
||||||
|
long i;
|
||||||
|
int firsterr = 0;
|
||||||
|
static struct rcu_perf_ops *perf_ops[] = {
|
||||||
|
&rcu_ops, &rcu_bh_ops, &srcu_ops, &sched_ops,
|
||||||
|
RCUPERF_TASKS_OPS
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!torture_init_begin(perf_type, verbose, &perf_runnable))
|
||||||
|
return -EBUSY;
|
||||||
|
|
||||||
|
/* Process args and tell the world that the perf'er is on the job. */
|
||||||
|
for (i = 0; i < ARRAY_SIZE(perf_ops); i++) {
|
||||||
|
cur_ops = perf_ops[i];
|
||||||
|
if (strcmp(perf_type, cur_ops->name) == 0)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (i == ARRAY_SIZE(perf_ops)) {
|
||||||
|
pr_alert("rcu-perf: invalid perf type: \"%s\"\n",
|
||||||
|
perf_type);
|
||||||
|
pr_alert("rcu-perf types:");
|
||||||
|
for (i = 0; i < ARRAY_SIZE(perf_ops); i++)
|
||||||
|
pr_alert(" %s", perf_ops[i]->name);
|
||||||
|
pr_alert("\n");
|
||||||
|
firsterr = -EINVAL;
|
||||||
|
goto unwind;
|
||||||
|
}
|
||||||
|
if (cur_ops->init)
|
||||||
|
cur_ops->init();
|
||||||
|
|
||||||
|
nrealwriters = compute_real(nwriters);
|
||||||
|
nrealreaders = compute_real(nreaders);
|
||||||
|
atomic_set(&n_rcu_perf_reader_started, 0);
|
||||||
|
atomic_set(&n_rcu_perf_writer_started, 0);
|
||||||
|
atomic_set(&n_rcu_perf_writer_finished, 0);
|
||||||
|
rcu_perf_print_module_parms(cur_ops, "Start of test");
|
||||||
|
|
||||||
|
/* Start up the kthreads. */
|
||||||
|
|
||||||
|
if (shutdown) {
|
||||||
|
init_waitqueue_head(&shutdown_wq);
|
||||||
|
firsterr = torture_create_kthread(rcu_perf_shutdown, NULL,
|
||||||
|
shutdown_task);
|
||||||
|
if (firsterr)
|
||||||
|
goto unwind;
|
||||||
|
schedule_timeout_uninterruptible(1);
|
||||||
|
}
|
||||||
|
reader_tasks = kcalloc(nrealreaders, sizeof(reader_tasks[0]),
|
||||||
|
GFP_KERNEL);
|
||||||
|
if (reader_tasks == NULL) {
|
||||||
|
VERBOSE_PERFOUT_ERRSTRING("out of memory");
|
||||||
|
firsterr = -ENOMEM;
|
||||||
|
goto unwind;
|
||||||
|
}
|
||||||
|
for (i = 0; i < nrealreaders; i++) {
|
||||||
|
firsterr = torture_create_kthread(rcu_perf_reader, (void *)i,
|
||||||
|
reader_tasks[i]);
|
||||||
|
if (firsterr)
|
||||||
|
goto unwind;
|
||||||
|
}
|
||||||
|
while (atomic_read(&n_rcu_perf_reader_started) < nrealreaders)
|
||||||
|
schedule_timeout_uninterruptible(1);
|
||||||
|
writer_tasks = kcalloc(nrealwriters, sizeof(reader_tasks[0]),
|
||||||
|
GFP_KERNEL);
|
||||||
|
writer_durations = kcalloc(nrealwriters, sizeof(*writer_durations),
|
||||||
|
GFP_KERNEL);
|
||||||
|
writer_n_durations =
|
||||||
|
kcalloc(nrealwriters, sizeof(*writer_n_durations),
|
||||||
|
GFP_KERNEL);
|
||||||
|
if (!writer_tasks || !writer_durations || !writer_n_durations) {
|
||||||
|
VERBOSE_PERFOUT_ERRSTRING("out of memory");
|
||||||
|
firsterr = -ENOMEM;
|
||||||
|
goto unwind;
|
||||||
|
}
|
||||||
|
for (i = 0; i < nrealwriters; i++) {
|
||||||
|
writer_durations[i] =
|
||||||
|
kcalloc(MAX_MEAS, sizeof(*writer_durations[i]),
|
||||||
|
GFP_KERNEL);
|
||||||
|
if (!writer_durations[i])
|
||||||
|
goto unwind;
|
||||||
|
firsterr = torture_create_kthread(rcu_perf_writer, (void *)i,
|
||||||
|
writer_tasks[i]);
|
||||||
|
if (firsterr)
|
||||||
|
goto unwind;
|
||||||
|
}
|
||||||
|
torture_init_end();
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
unwind:
|
||||||
|
torture_init_end();
|
||||||
|
rcu_perf_cleanup();
|
||||||
|
return firsterr;
|
||||||
|
}
|
||||||
|
|
||||||
|
module_init(rcu_perf_init);
|
||||||
|
module_exit(rcu_perf_cleanup);
|
@ -130,8 +130,8 @@ static struct rcu_torture __rcu *rcu_torture_current;
|
|||||||
static unsigned long rcu_torture_current_version;
|
static unsigned long rcu_torture_current_version;
|
||||||
static struct rcu_torture rcu_tortures[10 * RCU_TORTURE_PIPE_LEN];
|
static struct rcu_torture rcu_tortures[10 * RCU_TORTURE_PIPE_LEN];
|
||||||
static DEFINE_SPINLOCK(rcu_torture_lock);
|
static DEFINE_SPINLOCK(rcu_torture_lock);
|
||||||
static DEFINE_PER_CPU(long [RCU_TORTURE_PIPE_LEN + 1], rcu_torture_count) = { 0 };
|
static DEFINE_PER_CPU(long [RCU_TORTURE_PIPE_LEN + 1], rcu_torture_count);
|
||||||
static DEFINE_PER_CPU(long [RCU_TORTURE_PIPE_LEN + 1], rcu_torture_batch) = { 0 };
|
static DEFINE_PER_CPU(long [RCU_TORTURE_PIPE_LEN + 1], rcu_torture_batch);
|
||||||
static atomic_t rcu_torture_wcount[RCU_TORTURE_PIPE_LEN + 1];
|
static atomic_t rcu_torture_wcount[RCU_TORTURE_PIPE_LEN + 1];
|
||||||
static atomic_t n_rcu_torture_alloc;
|
static atomic_t n_rcu_torture_alloc;
|
||||||
static atomic_t n_rcu_torture_alloc_fail;
|
static atomic_t n_rcu_torture_alloc_fail;
|
||||||
@ -916,7 +916,7 @@ rcu_torture_fqs(void *arg)
|
|||||||
static int
|
static int
|
||||||
rcu_torture_writer(void *arg)
|
rcu_torture_writer(void *arg)
|
||||||
{
|
{
|
||||||
bool can_expedite = !rcu_gp_is_expedited();
|
bool can_expedite = !rcu_gp_is_expedited() && !rcu_gp_is_normal();
|
||||||
int expediting = 0;
|
int expediting = 0;
|
||||||
unsigned long gp_snap;
|
unsigned long gp_snap;
|
||||||
bool gp_cond1 = gp_cond, gp_exp1 = gp_exp, gp_normal1 = gp_normal;
|
bool gp_cond1 = gp_cond, gp_exp1 = gp_exp, gp_normal1 = gp_normal;
|
||||||
@ -932,7 +932,7 @@ rcu_torture_writer(void *arg)
|
|||||||
VERBOSE_TOROUT_STRING("rcu_torture_writer task started");
|
VERBOSE_TOROUT_STRING("rcu_torture_writer task started");
|
||||||
if (!can_expedite) {
|
if (!can_expedite) {
|
||||||
pr_alert("%s" TORTURE_FLAG
|
pr_alert("%s" TORTURE_FLAG
|
||||||
" Grace periods expedited from boot/sysfs for %s,\n",
|
" GP expediting controlled from boot/sysfs for %s,\n",
|
||||||
torture_type, cur_ops->name);
|
torture_type, cur_ops->name);
|
||||||
pr_alert("%s" TORTURE_FLAG
|
pr_alert("%s" TORTURE_FLAG
|
||||||
" Disabled dynamic grace-period expediting.\n",
|
" Disabled dynamic grace-period expediting.\n",
|
||||||
@ -1082,17 +1082,6 @@ rcu_torture_fakewriter(void *arg)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void rcutorture_trace_dump(void)
|
|
||||||
{
|
|
||||||
static atomic_t beenhere = ATOMIC_INIT(0);
|
|
||||||
|
|
||||||
if (atomic_read(&beenhere))
|
|
||||||
return;
|
|
||||||
if (atomic_xchg(&beenhere, 1) != 0)
|
|
||||||
return;
|
|
||||||
ftrace_dump(DUMP_ALL);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* RCU torture reader from timer handler. Dereferences rcu_torture_current,
|
* RCU torture reader from timer handler. Dereferences rcu_torture_current,
|
||||||
* incrementing the corresponding element of the pipeline array. The
|
* incrementing the corresponding element of the pipeline array. The
|
||||||
@ -1142,7 +1131,7 @@ static void rcu_torture_timer(unsigned long unused)
|
|||||||
if (pipe_count > 1) {
|
if (pipe_count > 1) {
|
||||||
do_trace_rcu_torture_read(cur_ops->name, &p->rtort_rcu, ts,
|
do_trace_rcu_torture_read(cur_ops->name, &p->rtort_rcu, ts,
|
||||||
started, completed);
|
started, completed);
|
||||||
rcutorture_trace_dump();
|
rcu_ftrace_dump(DUMP_ALL);
|
||||||
}
|
}
|
||||||
__this_cpu_inc(rcu_torture_count[pipe_count]);
|
__this_cpu_inc(rcu_torture_count[pipe_count]);
|
||||||
completed = completed - started;
|
completed = completed - started;
|
||||||
@ -1215,7 +1204,7 @@ rcu_torture_reader(void *arg)
|
|||||||
if (pipe_count > 1) {
|
if (pipe_count > 1) {
|
||||||
do_trace_rcu_torture_read(cur_ops->name, &p->rtort_rcu,
|
do_trace_rcu_torture_read(cur_ops->name, &p->rtort_rcu,
|
||||||
ts, started, completed);
|
ts, started, completed);
|
||||||
rcutorture_trace_dump();
|
rcu_ftrace_dump(DUMP_ALL);
|
||||||
}
|
}
|
||||||
__this_cpu_inc(rcu_torture_count[pipe_count]);
|
__this_cpu_inc(rcu_torture_count[pipe_count]);
|
||||||
completed = completed - started;
|
completed = completed - started;
|
||||||
@ -1333,7 +1322,7 @@ rcu_torture_stats_print(void)
|
|||||||
rcu_torture_writer_state,
|
rcu_torture_writer_state,
|
||||||
gpnum, completed, flags);
|
gpnum, completed, flags);
|
||||||
show_rcu_gp_kthreads();
|
show_rcu_gp_kthreads();
|
||||||
rcutorture_trace_dump();
|
rcu_ftrace_dump(DUMP_ALL);
|
||||||
}
|
}
|
||||||
rtcv_snap = rcu_torture_current_version;
|
rtcv_snap = rcu_torture_current_version;
|
||||||
}
|
}
|
||||||
@ -1489,7 +1478,9 @@ static int rcu_torture_barrier_cbs(void *arg)
|
|||||||
* The above smp_load_acquire() ensures barrier_phase load
|
* The above smp_load_acquire() ensures barrier_phase load
|
||||||
* is ordered before the folloiwng ->call().
|
* is ordered before the folloiwng ->call().
|
||||||
*/
|
*/
|
||||||
|
local_irq_disable(); /* Just to test no-irq call_rcu(). */
|
||||||
cur_ops->call(&rcu, rcu_torture_barrier_cbf);
|
cur_ops->call(&rcu, rcu_torture_barrier_cbf);
|
||||||
|
local_irq_enable();
|
||||||
if (atomic_dec_and_test(&barrier_cbs_count))
|
if (atomic_dec_and_test(&barrier_cbs_count))
|
||||||
wake_up(&barrier_wq);
|
wake_up(&barrier_wq);
|
||||||
} while (!torture_must_stop());
|
} while (!torture_must_stop());
|
||||||
@ -1596,7 +1587,7 @@ static int rcutorture_cpu_notify(struct notifier_block *self,
|
|||||||
{
|
{
|
||||||
long cpu = (long)hcpu;
|
long cpu = (long)hcpu;
|
||||||
|
|
||||||
switch (action) {
|
switch (action & ~CPU_TASKS_FROZEN) {
|
||||||
case CPU_ONLINE:
|
case CPU_ONLINE:
|
||||||
case CPU_DOWN_FAILED:
|
case CPU_DOWN_FAILED:
|
||||||
(void)rcutorture_booster_init(cpu);
|
(void)rcutorture_booster_init(cpu);
|
||||||
|
@ -102,6 +102,8 @@ struct rcu_state sname##_state = { \
|
|||||||
.barrier_mutex = __MUTEX_INITIALIZER(sname##_state.barrier_mutex), \
|
.barrier_mutex = __MUTEX_INITIALIZER(sname##_state.barrier_mutex), \
|
||||||
.name = RCU_STATE_NAME(sname), \
|
.name = RCU_STATE_NAME(sname), \
|
||||||
.abbr = sabbr, \
|
.abbr = sabbr, \
|
||||||
|
.exp_mutex = __MUTEX_INITIALIZER(sname##_state.exp_mutex), \
|
||||||
|
.exp_wake_mutex = __MUTEX_INITIALIZER(sname##_state.exp_wake_mutex), \
|
||||||
}
|
}
|
||||||
|
|
||||||
RCU_STATE_INITIALIZER(rcu_sched, 's', call_rcu_sched);
|
RCU_STATE_INITIALIZER(rcu_sched, 's', call_rcu_sched);
|
||||||
@ -370,6 +372,21 @@ void rcu_all_qs(void)
|
|||||||
rcu_momentary_dyntick_idle();
|
rcu_momentary_dyntick_idle();
|
||||||
local_irq_restore(flags);
|
local_irq_restore(flags);
|
||||||
}
|
}
|
||||||
|
if (unlikely(raw_cpu_read(rcu_sched_data.cpu_no_qs.b.exp))) {
|
||||||
|
/*
|
||||||
|
* Yes, we just checked a per-CPU variable with preemption
|
||||||
|
* enabled, so we might be migrated to some other CPU at
|
||||||
|
* this point. That is OK because in that case, the
|
||||||
|
* migration will supply the needed quiescent state.
|
||||||
|
* We might end up needlessly disabling preemption and
|
||||||
|
* invoking rcu_sched_qs() on the destination CPU, but
|
||||||
|
* the probability and cost are both quite low, so this
|
||||||
|
* should not be a problem in practice.
|
||||||
|
*/
|
||||||
|
preempt_disable();
|
||||||
|
rcu_sched_qs();
|
||||||
|
preempt_enable();
|
||||||
|
}
|
||||||
this_cpu_inc(rcu_qs_ctr);
|
this_cpu_inc(rcu_qs_ctr);
|
||||||
barrier(); /* Avoid RCU read-side critical sections leaking up. */
|
barrier(); /* Avoid RCU read-side critical sections leaking up. */
|
||||||
}
|
}
|
||||||
@ -385,9 +402,11 @@ module_param(qlowmark, long, 0444);
|
|||||||
|
|
||||||
static ulong jiffies_till_first_fqs = ULONG_MAX;
|
static ulong jiffies_till_first_fqs = ULONG_MAX;
|
||||||
static ulong jiffies_till_next_fqs = ULONG_MAX;
|
static ulong jiffies_till_next_fqs = ULONG_MAX;
|
||||||
|
static bool rcu_kick_kthreads;
|
||||||
|
|
||||||
module_param(jiffies_till_first_fqs, ulong, 0644);
|
module_param(jiffies_till_first_fqs, ulong, 0644);
|
||||||
module_param(jiffies_till_next_fqs, ulong, 0644);
|
module_param(jiffies_till_next_fqs, ulong, 0644);
|
||||||
|
module_param(rcu_kick_kthreads, bool, 0644);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* How long the grace period must be before we start recruiting
|
* How long the grace period must be before we start recruiting
|
||||||
@ -459,6 +478,28 @@ unsigned long rcu_batches_completed_bh(void)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(rcu_batches_completed_bh);
|
EXPORT_SYMBOL_GPL(rcu_batches_completed_bh);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return the number of RCU expedited batches completed thus far for
|
||||||
|
* debug & stats. Odd numbers mean that a batch is in progress, even
|
||||||
|
* numbers mean idle. The value returned will thus be roughly double
|
||||||
|
* the cumulative batches since boot.
|
||||||
|
*/
|
||||||
|
unsigned long rcu_exp_batches_completed(void)
|
||||||
|
{
|
||||||
|
return rcu_state_p->expedited_sequence;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rcu_exp_batches_completed);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return the number of RCU-sched expedited batches completed thus far
|
||||||
|
* for debug & stats. Similar to rcu_exp_batches_completed().
|
||||||
|
*/
|
||||||
|
unsigned long rcu_exp_batches_completed_sched(void)
|
||||||
|
{
|
||||||
|
return rcu_sched_state.expedited_sequence;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rcu_exp_batches_completed_sched);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Force a quiescent state.
|
* Force a quiescent state.
|
||||||
*/
|
*/
|
||||||
@ -637,7 +678,7 @@ static void rcu_eqs_enter_common(long long oldval, bool user)
|
|||||||
idle_task(smp_processor_id());
|
idle_task(smp_processor_id());
|
||||||
|
|
||||||
trace_rcu_dyntick(TPS("Error on entry: not idle task"), oldval, 0);
|
trace_rcu_dyntick(TPS("Error on entry: not idle task"), oldval, 0);
|
||||||
ftrace_dump(DUMP_ORIG);
|
rcu_ftrace_dump(DUMP_ORIG);
|
||||||
WARN_ONCE(1, "Current pid: %d comm: %s / Idle pid: %d comm: %s",
|
WARN_ONCE(1, "Current pid: %d comm: %s / Idle pid: %d comm: %s",
|
||||||
current->pid, current->comm,
|
current->pid, current->comm,
|
||||||
idle->pid, idle->comm); /* must be idle task! */
|
idle->pid, idle->comm); /* must be idle task! */
|
||||||
@ -799,7 +840,7 @@ static void rcu_eqs_exit_common(long long oldval, int user)
|
|||||||
|
|
||||||
trace_rcu_dyntick(TPS("Error on exit: not idle task"),
|
trace_rcu_dyntick(TPS("Error on exit: not idle task"),
|
||||||
oldval, rdtp->dynticks_nesting);
|
oldval, rdtp->dynticks_nesting);
|
||||||
ftrace_dump(DUMP_ORIG);
|
rcu_ftrace_dump(DUMP_ORIG);
|
||||||
WARN_ONCE(1, "Current pid: %d comm: %s / Idle pid: %d comm: %s",
|
WARN_ONCE(1, "Current pid: %d comm: %s / Idle pid: %d comm: %s",
|
||||||
current->pid, current->comm,
|
current->pid, current->comm,
|
||||||
idle->pid, idle->comm); /* must be idle task! */
|
idle->pid, idle->comm); /* must be idle task! */
|
||||||
@ -1224,8 +1265,10 @@ static void rcu_check_gp_kthread_starvation(struct rcu_state *rsp)
|
|||||||
rsp->gp_flags,
|
rsp->gp_flags,
|
||||||
gp_state_getname(rsp->gp_state), rsp->gp_state,
|
gp_state_getname(rsp->gp_state), rsp->gp_state,
|
||||||
rsp->gp_kthread ? rsp->gp_kthread->state : ~0);
|
rsp->gp_kthread ? rsp->gp_kthread->state : ~0);
|
||||||
if (rsp->gp_kthread)
|
if (rsp->gp_kthread) {
|
||||||
sched_show_task(rsp->gp_kthread);
|
sched_show_task(rsp->gp_kthread);
|
||||||
|
wake_up_process(rsp->gp_kthread);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1249,6 +1292,25 @@ static void rcu_dump_cpu_stacks(struct rcu_state *rsp)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If too much time has passed in the current grace period, and if
|
||||||
|
* so configured, go kick the relevant kthreads.
|
||||||
|
*/
|
||||||
|
static void rcu_stall_kick_kthreads(struct rcu_state *rsp)
|
||||||
|
{
|
||||||
|
unsigned long j;
|
||||||
|
|
||||||
|
if (!rcu_kick_kthreads)
|
||||||
|
return;
|
||||||
|
j = READ_ONCE(rsp->jiffies_kick_kthreads);
|
||||||
|
if (time_after(jiffies, j) && rsp->gp_kthread) {
|
||||||
|
WARN_ONCE(1, "Kicking %s grace-period kthread\n", rsp->name);
|
||||||
|
rcu_ftrace_dump(DUMP_ALL);
|
||||||
|
wake_up_process(rsp->gp_kthread);
|
||||||
|
WRITE_ONCE(rsp->jiffies_kick_kthreads, j + HZ);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void print_other_cpu_stall(struct rcu_state *rsp, unsigned long gpnum)
|
static void print_other_cpu_stall(struct rcu_state *rsp, unsigned long gpnum)
|
||||||
{
|
{
|
||||||
int cpu;
|
int cpu;
|
||||||
@ -1260,6 +1322,11 @@ static void print_other_cpu_stall(struct rcu_state *rsp, unsigned long gpnum)
|
|||||||
struct rcu_node *rnp = rcu_get_root(rsp);
|
struct rcu_node *rnp = rcu_get_root(rsp);
|
||||||
long totqlen = 0;
|
long totqlen = 0;
|
||||||
|
|
||||||
|
/* Kick and suppress, if so configured. */
|
||||||
|
rcu_stall_kick_kthreads(rsp);
|
||||||
|
if (rcu_cpu_stall_suppress)
|
||||||
|
return;
|
||||||
|
|
||||||
/* Only let one CPU complain about others per time interval. */
|
/* Only let one CPU complain about others per time interval. */
|
||||||
|
|
||||||
raw_spin_lock_irqsave_rcu_node(rnp, flags);
|
raw_spin_lock_irqsave_rcu_node(rnp, flags);
|
||||||
@ -1333,6 +1400,11 @@ static void print_cpu_stall(struct rcu_state *rsp)
|
|||||||
struct rcu_node *rnp = rcu_get_root(rsp);
|
struct rcu_node *rnp = rcu_get_root(rsp);
|
||||||
long totqlen = 0;
|
long totqlen = 0;
|
||||||
|
|
||||||
|
/* Kick and suppress, if so configured. */
|
||||||
|
rcu_stall_kick_kthreads(rsp);
|
||||||
|
if (rcu_cpu_stall_suppress)
|
||||||
|
return;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* OK, time to rat on ourselves...
|
* OK, time to rat on ourselves...
|
||||||
* See Documentation/RCU/stallwarn.txt for info on how to debug
|
* See Documentation/RCU/stallwarn.txt for info on how to debug
|
||||||
@ -1377,8 +1449,10 @@ static void check_cpu_stall(struct rcu_state *rsp, struct rcu_data *rdp)
|
|||||||
unsigned long js;
|
unsigned long js;
|
||||||
struct rcu_node *rnp;
|
struct rcu_node *rnp;
|
||||||
|
|
||||||
if (rcu_cpu_stall_suppress || !rcu_gp_in_progress(rsp))
|
if ((rcu_cpu_stall_suppress && !rcu_kick_kthreads) ||
|
||||||
|
!rcu_gp_in_progress(rsp))
|
||||||
return;
|
return;
|
||||||
|
rcu_stall_kick_kthreads(rsp);
|
||||||
j = jiffies;
|
j = jiffies;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2117,8 +2191,11 @@ static int __noreturn rcu_gp_kthread(void *arg)
|
|||||||
}
|
}
|
||||||
ret = 0;
|
ret = 0;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (!ret)
|
if (!ret) {
|
||||||
rsp->jiffies_force_qs = jiffies + j;
|
rsp->jiffies_force_qs = jiffies + j;
|
||||||
|
WRITE_ONCE(rsp->jiffies_kick_kthreads,
|
||||||
|
jiffies + 3 * j);
|
||||||
|
}
|
||||||
trace_rcu_grace_period(rsp->name,
|
trace_rcu_grace_period(rsp->name,
|
||||||
READ_ONCE(rsp->gpnum),
|
READ_ONCE(rsp->gpnum),
|
||||||
TPS("fqswait"));
|
TPS("fqswait"));
|
||||||
@ -2144,6 +2221,15 @@ static int __noreturn rcu_gp_kthread(void *arg)
|
|||||||
TPS("fqsend"));
|
TPS("fqsend"));
|
||||||
cond_resched_rcu_qs();
|
cond_resched_rcu_qs();
|
||||||
WRITE_ONCE(rsp->gp_activity, jiffies);
|
WRITE_ONCE(rsp->gp_activity, jiffies);
|
||||||
|
ret = 0; /* Force full wait till next FQS. */
|
||||||
|
j = jiffies_till_next_fqs;
|
||||||
|
if (j > HZ) {
|
||||||
|
j = HZ;
|
||||||
|
jiffies_till_next_fqs = HZ;
|
||||||
|
} else if (j < 1) {
|
||||||
|
j = 1;
|
||||||
|
jiffies_till_next_fqs = 1;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
/* Deal with stray signal. */
|
/* Deal with stray signal. */
|
||||||
cond_resched_rcu_qs();
|
cond_resched_rcu_qs();
|
||||||
@ -2152,14 +2238,12 @@ static int __noreturn rcu_gp_kthread(void *arg)
|
|||||||
trace_rcu_grace_period(rsp->name,
|
trace_rcu_grace_period(rsp->name,
|
||||||
READ_ONCE(rsp->gpnum),
|
READ_ONCE(rsp->gpnum),
|
||||||
TPS("fqswaitsig"));
|
TPS("fqswaitsig"));
|
||||||
}
|
ret = 1; /* Keep old FQS timing. */
|
||||||
j = jiffies_till_next_fqs;
|
j = jiffies;
|
||||||
if (j > HZ) {
|
if (time_after(jiffies, rsp->jiffies_force_qs))
|
||||||
j = HZ;
|
|
||||||
jiffies_till_next_fqs = HZ;
|
|
||||||
} else if (j < 1) {
|
|
||||||
j = 1;
|
j = 1;
|
||||||
jiffies_till_next_fqs = 1;
|
else
|
||||||
|
j = rsp->jiffies_force_qs - j;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3376,8 +3460,12 @@ static void rcu_exp_gp_seq_end(struct rcu_state *rsp)
|
|||||||
}
|
}
|
||||||
static unsigned long rcu_exp_gp_seq_snap(struct rcu_state *rsp)
|
static unsigned long rcu_exp_gp_seq_snap(struct rcu_state *rsp)
|
||||||
{
|
{
|
||||||
|
unsigned long s;
|
||||||
|
|
||||||
smp_mb(); /* Caller's modifications seen first by other CPUs. */
|
smp_mb(); /* Caller's modifications seen first by other CPUs. */
|
||||||
return rcu_seq_snap(&rsp->expedited_sequence);
|
s = rcu_seq_snap(&rsp->expedited_sequence);
|
||||||
|
trace_rcu_exp_grace_period(rsp->name, s, TPS("snap"));
|
||||||
|
return s;
|
||||||
}
|
}
|
||||||
static bool rcu_exp_gp_seq_done(struct rcu_state *rsp, unsigned long s)
|
static bool rcu_exp_gp_seq_done(struct rcu_state *rsp, unsigned long s)
|
||||||
{
|
{
|
||||||
@ -3469,7 +3557,7 @@ static void __maybe_unused sync_exp_reset_tree(struct rcu_state *rsp)
|
|||||||
* for the current expedited grace period. Works only for preemptible
|
* for the current expedited grace period. Works only for preemptible
|
||||||
* RCU -- other RCU implementation use other means.
|
* RCU -- other RCU implementation use other means.
|
||||||
*
|
*
|
||||||
* Caller must hold the root rcu_node's exp_funnel_mutex.
|
* Caller must hold the rcu_state's exp_mutex.
|
||||||
*/
|
*/
|
||||||
static int sync_rcu_preempt_exp_done(struct rcu_node *rnp)
|
static int sync_rcu_preempt_exp_done(struct rcu_node *rnp)
|
||||||
{
|
{
|
||||||
@ -3485,8 +3573,8 @@ static int sync_rcu_preempt_exp_done(struct rcu_node *rnp)
|
|||||||
* recursively up the tree. (Calm down, calm down, we do the recursion
|
* recursively up the tree. (Calm down, calm down, we do the recursion
|
||||||
* iteratively!)
|
* iteratively!)
|
||||||
*
|
*
|
||||||
* Caller must hold the root rcu_node's exp_funnel_mutex and the
|
* Caller must hold the rcu_state's exp_mutex and the specified rcu_node
|
||||||
* specified rcu_node structure's ->lock.
|
* structure's ->lock.
|
||||||
*/
|
*/
|
||||||
static void __rcu_report_exp_rnp(struct rcu_state *rsp, struct rcu_node *rnp,
|
static void __rcu_report_exp_rnp(struct rcu_state *rsp, struct rcu_node *rnp,
|
||||||
bool wake, unsigned long flags)
|
bool wake, unsigned long flags)
|
||||||
@ -3523,7 +3611,7 @@ static void __rcu_report_exp_rnp(struct rcu_state *rsp, struct rcu_node *rnp,
|
|||||||
* Report expedited quiescent state for specified node. This is a
|
* Report expedited quiescent state for specified node. This is a
|
||||||
* lock-acquisition wrapper function for __rcu_report_exp_rnp().
|
* lock-acquisition wrapper function for __rcu_report_exp_rnp().
|
||||||
*
|
*
|
||||||
* Caller must hold the root rcu_node's exp_funnel_mutex.
|
* Caller must hold the rcu_state's exp_mutex.
|
||||||
*/
|
*/
|
||||||
static void __maybe_unused rcu_report_exp_rnp(struct rcu_state *rsp,
|
static void __maybe_unused rcu_report_exp_rnp(struct rcu_state *rsp,
|
||||||
struct rcu_node *rnp, bool wake)
|
struct rcu_node *rnp, bool wake)
|
||||||
@ -3536,8 +3624,8 @@ static void __maybe_unused rcu_report_exp_rnp(struct rcu_state *rsp,
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Report expedited quiescent state for multiple CPUs, all covered by the
|
* Report expedited quiescent state for multiple CPUs, all covered by the
|
||||||
* specified leaf rcu_node structure. Caller must hold the root
|
* specified leaf rcu_node structure. Caller must hold the rcu_state's
|
||||||
* rcu_node's exp_funnel_mutex.
|
* exp_mutex.
|
||||||
*/
|
*/
|
||||||
static void rcu_report_exp_cpu_mult(struct rcu_state *rsp, struct rcu_node *rnp,
|
static void rcu_report_exp_cpu_mult(struct rcu_state *rsp, struct rcu_node *rnp,
|
||||||
unsigned long mask, bool wake)
|
unsigned long mask, bool wake)
|
||||||
@ -3555,7 +3643,6 @@ static void rcu_report_exp_cpu_mult(struct rcu_state *rsp, struct rcu_node *rnp,
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Report expedited quiescent state for specified rcu_data (CPU).
|
* Report expedited quiescent state for specified rcu_data (CPU).
|
||||||
* Caller must hold the root rcu_node's exp_funnel_mutex.
|
|
||||||
*/
|
*/
|
||||||
static void rcu_report_exp_rdp(struct rcu_state *rsp, struct rcu_data *rdp,
|
static void rcu_report_exp_rdp(struct rcu_state *rsp, struct rcu_data *rdp,
|
||||||
bool wake)
|
bool wake)
|
||||||
@ -3564,15 +3651,11 @@ static void rcu_report_exp_rdp(struct rcu_state *rsp, struct rcu_data *rdp,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Common code for synchronize_{rcu,sched}_expedited() work-done checking. */
|
/* Common code for synchronize_{rcu,sched}_expedited() work-done checking. */
|
||||||
static bool sync_exp_work_done(struct rcu_state *rsp, struct rcu_node *rnp,
|
static bool sync_exp_work_done(struct rcu_state *rsp, atomic_long_t *stat,
|
||||||
struct rcu_data *rdp,
|
unsigned long s)
|
||||||
atomic_long_t *stat, unsigned long s)
|
|
||||||
{
|
{
|
||||||
if (rcu_exp_gp_seq_done(rsp, s)) {
|
if (rcu_exp_gp_seq_done(rsp, s)) {
|
||||||
if (rnp)
|
trace_rcu_exp_grace_period(rsp->name, s, TPS("done"));
|
||||||
mutex_unlock(&rnp->exp_funnel_mutex);
|
|
||||||
else if (rdp)
|
|
||||||
mutex_unlock(&rdp->exp_funnel_mutex);
|
|
||||||
/* Ensure test happens before caller kfree(). */
|
/* Ensure test happens before caller kfree(). */
|
||||||
smp_mb__before_atomic(); /* ^^^ */
|
smp_mb__before_atomic(); /* ^^^ */
|
||||||
atomic_long_inc(stat);
|
atomic_long_inc(stat);
|
||||||
@ -3582,59 +3665,65 @@ static bool sync_exp_work_done(struct rcu_state *rsp, struct rcu_node *rnp,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Funnel-lock acquisition for expedited grace periods. Returns a
|
* Funnel-lock acquisition for expedited grace periods. Returns true
|
||||||
* pointer to the root rcu_node structure, or NULL if some other
|
* if some other task completed an expedited grace period that this task
|
||||||
* task did the expedited grace period for us.
|
* can piggy-back on, and with no mutex held. Otherwise, returns false
|
||||||
|
* with the mutex held, indicating that the caller must actually do the
|
||||||
|
* expedited grace period.
|
||||||
*/
|
*/
|
||||||
static struct rcu_node *exp_funnel_lock(struct rcu_state *rsp, unsigned long s)
|
static bool exp_funnel_lock(struct rcu_state *rsp, unsigned long s)
|
||||||
{
|
{
|
||||||
struct rcu_data *rdp = per_cpu_ptr(rsp->rda, raw_smp_processor_id());
|
struct rcu_data *rdp = per_cpu_ptr(rsp->rda, raw_smp_processor_id());
|
||||||
struct rcu_node *rnp0;
|
struct rcu_node *rnp = rdp->mynode;
|
||||||
struct rcu_node *rnp1 = NULL;
|
struct rcu_node *rnp_root = rcu_get_root(rsp);
|
||||||
|
|
||||||
|
/* Low-contention fastpath. */
|
||||||
|
if (ULONG_CMP_LT(READ_ONCE(rnp->exp_seq_rq), s) &&
|
||||||
|
(rnp == rnp_root ||
|
||||||
|
ULONG_CMP_LT(READ_ONCE(rnp_root->exp_seq_rq), s)) &&
|
||||||
|
!mutex_is_locked(&rsp->exp_mutex) &&
|
||||||
|
mutex_trylock(&rsp->exp_mutex))
|
||||||
|
goto fastpath;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* First try directly acquiring the root lock in order to reduce
|
* Each pass through the following loop works its way up
|
||||||
* latency in the common case where expedited grace periods are
|
* the rcu_node tree, returning if others have done the work or
|
||||||
* rare. We check mutex_is_locked() to avoid pathological levels of
|
* otherwise falls through to acquire rsp->exp_mutex. The mapping
|
||||||
* memory contention on ->exp_funnel_mutex in the heavy-load case.
|
* from CPU to rcu_node structure can be inexact, as it is just
|
||||||
|
* promoting locality and is not strictly needed for correctness.
|
||||||
*/
|
*/
|
||||||
rnp0 = rcu_get_root(rsp);
|
for (; rnp != NULL; rnp = rnp->parent) {
|
||||||
if (!mutex_is_locked(&rnp0->exp_funnel_mutex)) {
|
if (sync_exp_work_done(rsp, &rdp->exp_workdone1, s))
|
||||||
if (mutex_trylock(&rnp0->exp_funnel_mutex)) {
|
return true;
|
||||||
if (sync_exp_work_done(rsp, rnp0, NULL,
|
|
||||||
&rdp->expedited_workdone0, s))
|
|
||||||
return NULL;
|
|
||||||
return rnp0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/* Work not done, either wait here or go up. */
|
||||||
* Each pass through the following loop works its way
|
spin_lock(&rnp->exp_lock);
|
||||||
* up the rcu_node tree, returning if others have done the
|
if (ULONG_CMP_GE(rnp->exp_seq_rq, s)) {
|
||||||
* work or otherwise falls through holding the root rnp's
|
|
||||||
* ->exp_funnel_mutex. The mapping from CPU to rcu_node structure
|
/* Someone else doing GP, so wait for them. */
|
||||||
* can be inexact, as it is just promoting locality and is not
|
spin_unlock(&rnp->exp_lock);
|
||||||
* strictly needed for correctness.
|
trace_rcu_exp_funnel_lock(rsp->name, rnp->level,
|
||||||
*/
|
rnp->grplo, rnp->grphi,
|
||||||
if (sync_exp_work_done(rsp, NULL, NULL, &rdp->expedited_workdone1, s))
|
TPS("wait"));
|
||||||
return NULL;
|
wait_event(rnp->exp_wq[(s >> 1) & 0x3],
|
||||||
mutex_lock(&rdp->exp_funnel_mutex);
|
sync_exp_work_done(rsp,
|
||||||
rnp0 = rdp->mynode;
|
&rdp->exp_workdone2, s));
|
||||||
for (; rnp0 != NULL; rnp0 = rnp0->parent) {
|
return true;
|
||||||
if (sync_exp_work_done(rsp, rnp1, rdp,
|
|
||||||
&rdp->expedited_workdone2, s))
|
|
||||||
return NULL;
|
|
||||||
mutex_lock(&rnp0->exp_funnel_mutex);
|
|
||||||
if (rnp1)
|
|
||||||
mutex_unlock(&rnp1->exp_funnel_mutex);
|
|
||||||
else
|
|
||||||
mutex_unlock(&rdp->exp_funnel_mutex);
|
|
||||||
rnp1 = rnp0;
|
|
||||||
}
|
}
|
||||||
if (sync_exp_work_done(rsp, rnp1, rdp,
|
rnp->exp_seq_rq = s; /* Followers can wait on us. */
|
||||||
&rdp->expedited_workdone3, s))
|
spin_unlock(&rnp->exp_lock);
|
||||||
return NULL;
|
trace_rcu_exp_funnel_lock(rsp->name, rnp->level, rnp->grplo,
|
||||||
return rnp1;
|
rnp->grphi, TPS("nxtlvl"));
|
||||||
|
}
|
||||||
|
mutex_lock(&rsp->exp_mutex);
|
||||||
|
fastpath:
|
||||||
|
if (sync_exp_work_done(rsp, &rdp->exp_workdone3, s)) {
|
||||||
|
mutex_unlock(&rsp->exp_mutex);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
rcu_exp_gp_seq_start(rsp);
|
||||||
|
trace_rcu_exp_grace_period(rsp->name, s, TPS("start"));
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Invoked on each online non-idle CPU for expedited quiescent state. */
|
/* Invoked on each online non-idle CPU for expedited quiescent state. */
|
||||||
@ -3649,6 +3738,11 @@ static void sync_sched_exp_handler(void *data)
|
|||||||
if (!(READ_ONCE(rnp->expmask) & rdp->grpmask) ||
|
if (!(READ_ONCE(rnp->expmask) & rdp->grpmask) ||
|
||||||
__this_cpu_read(rcu_sched_data.cpu_no_qs.b.exp))
|
__this_cpu_read(rcu_sched_data.cpu_no_qs.b.exp))
|
||||||
return;
|
return;
|
||||||
|
if (rcu_is_cpu_rrupt_from_idle()) {
|
||||||
|
rcu_report_exp_rdp(&rcu_sched_state,
|
||||||
|
this_cpu_ptr(&rcu_sched_data), true);
|
||||||
|
return;
|
||||||
|
}
|
||||||
__this_cpu_write(rcu_sched_data.cpu_no_qs.b.exp, true);
|
__this_cpu_write(rcu_sched_data.cpu_no_qs.b.exp, true);
|
||||||
resched_cpu(smp_processor_id());
|
resched_cpu(smp_processor_id());
|
||||||
}
|
}
|
||||||
@ -3773,7 +3867,7 @@ static void synchronize_sched_expedited_wait(struct rcu_state *rsp)
|
|||||||
rsp->name);
|
rsp->name);
|
||||||
ndetected = 0;
|
ndetected = 0;
|
||||||
rcu_for_each_leaf_node(rsp, rnp) {
|
rcu_for_each_leaf_node(rsp, rnp) {
|
||||||
ndetected = rcu_print_task_exp_stall(rnp);
|
ndetected += rcu_print_task_exp_stall(rnp);
|
||||||
mask = 1;
|
mask = 1;
|
||||||
for (cpu = rnp->grplo; cpu <= rnp->grphi; cpu++, mask <<= 1) {
|
for (cpu = rnp->grplo; cpu <= rnp->grphi; cpu++, mask <<= 1) {
|
||||||
struct rcu_data *rdp;
|
struct rcu_data *rdp;
|
||||||
@ -3783,7 +3877,7 @@ static void synchronize_sched_expedited_wait(struct rcu_state *rsp)
|
|||||||
ndetected++;
|
ndetected++;
|
||||||
rdp = per_cpu_ptr(rsp->rda, cpu);
|
rdp = per_cpu_ptr(rsp->rda, cpu);
|
||||||
pr_cont(" %d-%c%c%c", cpu,
|
pr_cont(" %d-%c%c%c", cpu,
|
||||||
"O."[cpu_online(cpu)],
|
"O."[!!cpu_online(cpu)],
|
||||||
"o."[!!(rdp->grpmask & rnp->expmaskinit)],
|
"o."[!!(rdp->grpmask & rnp->expmaskinit)],
|
||||||
"N."[!!(rdp->grpmask & rnp->expmaskinitnext)]);
|
"N."[!!(rdp->grpmask & rnp->expmaskinitnext)]);
|
||||||
}
|
}
|
||||||
@ -3792,7 +3886,7 @@ static void synchronize_sched_expedited_wait(struct rcu_state *rsp)
|
|||||||
pr_cont(" } %lu jiffies s: %lu root: %#lx/%c\n",
|
pr_cont(" } %lu jiffies s: %lu root: %#lx/%c\n",
|
||||||
jiffies - jiffies_start, rsp->expedited_sequence,
|
jiffies - jiffies_start, rsp->expedited_sequence,
|
||||||
rnp_root->expmask, ".T"[!!rnp_root->exp_tasks]);
|
rnp_root->expmask, ".T"[!!rnp_root->exp_tasks]);
|
||||||
if (!ndetected) {
|
if (ndetected) {
|
||||||
pr_err("blocking rcu_node structures:");
|
pr_err("blocking rcu_node structures:");
|
||||||
rcu_for_each_node_breadth_first(rsp, rnp) {
|
rcu_for_each_node_breadth_first(rsp, rnp) {
|
||||||
if (rnp == rnp_root)
|
if (rnp == rnp_root)
|
||||||
@ -3818,6 +3912,41 @@ static void synchronize_sched_expedited_wait(struct rcu_state *rsp)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Wait for the current expedited grace period to complete, and then
|
||||||
|
* wake up everyone who piggybacked on the just-completed expedited
|
||||||
|
* grace period. Also update all the ->exp_seq_rq counters as needed
|
||||||
|
* in order to avoid counter-wrap problems.
|
||||||
|
*/
|
||||||
|
static void rcu_exp_wait_wake(struct rcu_state *rsp, unsigned long s)
|
||||||
|
{
|
||||||
|
struct rcu_node *rnp;
|
||||||
|
|
||||||
|
synchronize_sched_expedited_wait(rsp);
|
||||||
|
rcu_exp_gp_seq_end(rsp);
|
||||||
|
trace_rcu_exp_grace_period(rsp->name, s, TPS("end"));
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Switch over to wakeup mode, allowing the next GP, but -only- the
|
||||||
|
* next GP, to proceed.
|
||||||
|
*/
|
||||||
|
mutex_lock(&rsp->exp_wake_mutex);
|
||||||
|
mutex_unlock(&rsp->exp_mutex);
|
||||||
|
|
||||||
|
rcu_for_each_node_breadth_first(rsp, rnp) {
|
||||||
|
if (ULONG_CMP_LT(READ_ONCE(rnp->exp_seq_rq), s)) {
|
||||||
|
spin_lock(&rnp->exp_lock);
|
||||||
|
/* Recheck, avoid hang in case someone just arrived. */
|
||||||
|
if (ULONG_CMP_LT(rnp->exp_seq_rq, s))
|
||||||
|
rnp->exp_seq_rq = s;
|
||||||
|
spin_unlock(&rnp->exp_lock);
|
||||||
|
}
|
||||||
|
wake_up_all(&rnp->exp_wq[(rsp->expedited_sequence >> 1) & 0x3]);
|
||||||
|
}
|
||||||
|
trace_rcu_exp_grace_period(rsp->name, s, TPS("endwake"));
|
||||||
|
mutex_unlock(&rsp->exp_wake_mutex);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* synchronize_sched_expedited - Brute-force RCU-sched grace period
|
* synchronize_sched_expedited - Brute-force RCU-sched grace period
|
||||||
*
|
*
|
||||||
@ -3837,7 +3966,6 @@ static void synchronize_sched_expedited_wait(struct rcu_state *rsp)
|
|||||||
void synchronize_sched_expedited(void)
|
void synchronize_sched_expedited(void)
|
||||||
{
|
{
|
||||||
unsigned long s;
|
unsigned long s;
|
||||||
struct rcu_node *rnp;
|
|
||||||
struct rcu_state *rsp = &rcu_sched_state;
|
struct rcu_state *rsp = &rcu_sched_state;
|
||||||
|
|
||||||
/* If only one CPU, this is automatically a grace period. */
|
/* If only one CPU, this is automatically a grace period. */
|
||||||
@ -3852,17 +3980,14 @@ void synchronize_sched_expedited(void)
|
|||||||
|
|
||||||
/* Take a snapshot of the sequence number. */
|
/* Take a snapshot of the sequence number. */
|
||||||
s = rcu_exp_gp_seq_snap(rsp);
|
s = rcu_exp_gp_seq_snap(rsp);
|
||||||
|
if (exp_funnel_lock(rsp, s))
|
||||||
rnp = exp_funnel_lock(rsp, s);
|
|
||||||
if (rnp == NULL)
|
|
||||||
return; /* Someone else did our work for us. */
|
return; /* Someone else did our work for us. */
|
||||||
|
|
||||||
rcu_exp_gp_seq_start(rsp);
|
/* Initialize the rcu_node tree in preparation for the wait. */
|
||||||
sync_rcu_exp_select_cpus(rsp, sync_sched_exp_handler);
|
sync_rcu_exp_select_cpus(rsp, sync_sched_exp_handler);
|
||||||
synchronize_sched_expedited_wait(rsp);
|
|
||||||
|
|
||||||
rcu_exp_gp_seq_end(rsp);
|
/* Wait and clean up, including waking everyone. */
|
||||||
mutex_unlock(&rnp->exp_funnel_mutex);
|
rcu_exp_wait_wake(rsp, s);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(synchronize_sched_expedited);
|
EXPORT_SYMBOL_GPL(synchronize_sched_expedited);
|
||||||
|
|
||||||
@ -4162,7 +4287,6 @@ rcu_boot_init_percpu_data(int cpu, struct rcu_state *rsp)
|
|||||||
WARN_ON_ONCE(atomic_read(&rdp->dynticks->dynticks) != 1);
|
WARN_ON_ONCE(atomic_read(&rdp->dynticks->dynticks) != 1);
|
||||||
rdp->cpu = cpu;
|
rdp->cpu = cpu;
|
||||||
rdp->rsp = rsp;
|
rdp->rsp = rsp;
|
||||||
mutex_init(&rdp->exp_funnel_mutex);
|
|
||||||
rcu_boot_init_nocb_percpu_data(rdp);
|
rcu_boot_init_nocb_percpu_data(rdp);
|
||||||
raw_spin_unlock_irqrestore_rcu_node(rnp, flags);
|
raw_spin_unlock_irqrestore_rcu_node(rnp, flags);
|
||||||
}
|
}
|
||||||
@ -4420,10 +4544,8 @@ static void __init rcu_init_one(struct rcu_state *rsp)
|
|||||||
{
|
{
|
||||||
static const char * const buf[] = RCU_NODE_NAME_INIT;
|
static const char * const buf[] = RCU_NODE_NAME_INIT;
|
||||||
static const char * const fqs[] = RCU_FQS_NAME_INIT;
|
static const char * const fqs[] = RCU_FQS_NAME_INIT;
|
||||||
static const char * const exp[] = RCU_EXP_NAME_INIT;
|
|
||||||
static struct lock_class_key rcu_node_class[RCU_NUM_LVLS];
|
static struct lock_class_key rcu_node_class[RCU_NUM_LVLS];
|
||||||
static struct lock_class_key rcu_fqs_class[RCU_NUM_LVLS];
|
static struct lock_class_key rcu_fqs_class[RCU_NUM_LVLS];
|
||||||
static struct lock_class_key rcu_exp_class[RCU_NUM_LVLS];
|
|
||||||
static u8 fl_mask = 0x1;
|
static u8 fl_mask = 0x1;
|
||||||
|
|
||||||
int levelcnt[RCU_NUM_LVLS]; /* # nodes in each level. */
|
int levelcnt[RCU_NUM_LVLS]; /* # nodes in each level. */
|
||||||
@ -4482,9 +4604,11 @@ static void __init rcu_init_one(struct rcu_state *rsp)
|
|||||||
rnp->level = i;
|
rnp->level = i;
|
||||||
INIT_LIST_HEAD(&rnp->blkd_tasks);
|
INIT_LIST_HEAD(&rnp->blkd_tasks);
|
||||||
rcu_init_one_nocb(rnp);
|
rcu_init_one_nocb(rnp);
|
||||||
mutex_init(&rnp->exp_funnel_mutex);
|
init_waitqueue_head(&rnp->exp_wq[0]);
|
||||||
lockdep_set_class_and_name(&rnp->exp_funnel_mutex,
|
init_waitqueue_head(&rnp->exp_wq[1]);
|
||||||
&rcu_exp_class[i], exp[i]);
|
init_waitqueue_head(&rnp->exp_wq[2]);
|
||||||
|
init_waitqueue_head(&rnp->exp_wq[3]);
|
||||||
|
spin_lock_init(&rnp->exp_lock);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,7 +70,6 @@
|
|||||||
# define NUM_RCU_LVL_INIT { NUM_RCU_LVL_0 }
|
# define NUM_RCU_LVL_INIT { NUM_RCU_LVL_0 }
|
||||||
# define RCU_NODE_NAME_INIT { "rcu_node_0" }
|
# define RCU_NODE_NAME_INIT { "rcu_node_0" }
|
||||||
# define RCU_FQS_NAME_INIT { "rcu_node_fqs_0" }
|
# define RCU_FQS_NAME_INIT { "rcu_node_fqs_0" }
|
||||||
# define RCU_EXP_NAME_INIT { "rcu_node_exp_0" }
|
|
||||||
#elif NR_CPUS <= RCU_FANOUT_2
|
#elif NR_CPUS <= RCU_FANOUT_2
|
||||||
# define RCU_NUM_LVLS 2
|
# define RCU_NUM_LVLS 2
|
||||||
# define NUM_RCU_LVL_0 1
|
# define NUM_RCU_LVL_0 1
|
||||||
@ -79,7 +78,6 @@
|
|||||||
# define NUM_RCU_LVL_INIT { NUM_RCU_LVL_0, NUM_RCU_LVL_1 }
|
# define NUM_RCU_LVL_INIT { NUM_RCU_LVL_0, NUM_RCU_LVL_1 }
|
||||||
# define RCU_NODE_NAME_INIT { "rcu_node_0", "rcu_node_1" }
|
# define RCU_NODE_NAME_INIT { "rcu_node_0", "rcu_node_1" }
|
||||||
# define RCU_FQS_NAME_INIT { "rcu_node_fqs_0", "rcu_node_fqs_1" }
|
# define RCU_FQS_NAME_INIT { "rcu_node_fqs_0", "rcu_node_fqs_1" }
|
||||||
# define RCU_EXP_NAME_INIT { "rcu_node_exp_0", "rcu_node_exp_1" }
|
|
||||||
#elif NR_CPUS <= RCU_FANOUT_3
|
#elif NR_CPUS <= RCU_FANOUT_3
|
||||||
# define RCU_NUM_LVLS 3
|
# define RCU_NUM_LVLS 3
|
||||||
# define NUM_RCU_LVL_0 1
|
# define NUM_RCU_LVL_0 1
|
||||||
@ -89,7 +87,6 @@
|
|||||||
# define NUM_RCU_LVL_INIT { NUM_RCU_LVL_0, NUM_RCU_LVL_1, NUM_RCU_LVL_2 }
|
# define NUM_RCU_LVL_INIT { NUM_RCU_LVL_0, NUM_RCU_LVL_1, NUM_RCU_LVL_2 }
|
||||||
# define RCU_NODE_NAME_INIT { "rcu_node_0", "rcu_node_1", "rcu_node_2" }
|
# define RCU_NODE_NAME_INIT { "rcu_node_0", "rcu_node_1", "rcu_node_2" }
|
||||||
# define RCU_FQS_NAME_INIT { "rcu_node_fqs_0", "rcu_node_fqs_1", "rcu_node_fqs_2" }
|
# define RCU_FQS_NAME_INIT { "rcu_node_fqs_0", "rcu_node_fqs_1", "rcu_node_fqs_2" }
|
||||||
# define RCU_EXP_NAME_INIT { "rcu_node_exp_0", "rcu_node_exp_1", "rcu_node_exp_2" }
|
|
||||||
#elif NR_CPUS <= RCU_FANOUT_4
|
#elif NR_CPUS <= RCU_FANOUT_4
|
||||||
# define RCU_NUM_LVLS 4
|
# define RCU_NUM_LVLS 4
|
||||||
# define NUM_RCU_LVL_0 1
|
# define NUM_RCU_LVL_0 1
|
||||||
@ -100,7 +97,6 @@
|
|||||||
# define NUM_RCU_LVL_INIT { NUM_RCU_LVL_0, NUM_RCU_LVL_1, NUM_RCU_LVL_2, NUM_RCU_LVL_3 }
|
# define NUM_RCU_LVL_INIT { NUM_RCU_LVL_0, NUM_RCU_LVL_1, NUM_RCU_LVL_2, NUM_RCU_LVL_3 }
|
||||||
# define RCU_NODE_NAME_INIT { "rcu_node_0", "rcu_node_1", "rcu_node_2", "rcu_node_3" }
|
# define RCU_NODE_NAME_INIT { "rcu_node_0", "rcu_node_1", "rcu_node_2", "rcu_node_3" }
|
||||||
# define RCU_FQS_NAME_INIT { "rcu_node_fqs_0", "rcu_node_fqs_1", "rcu_node_fqs_2", "rcu_node_fqs_3" }
|
# define RCU_FQS_NAME_INIT { "rcu_node_fqs_0", "rcu_node_fqs_1", "rcu_node_fqs_2", "rcu_node_fqs_3" }
|
||||||
# define RCU_EXP_NAME_INIT { "rcu_node_exp_0", "rcu_node_exp_1", "rcu_node_exp_2", "rcu_node_exp_3" }
|
|
||||||
#else
|
#else
|
||||||
# error "CONFIG_RCU_FANOUT insufficient for NR_CPUS"
|
# error "CONFIG_RCU_FANOUT insufficient for NR_CPUS"
|
||||||
#endif /* #if (NR_CPUS) <= RCU_FANOUT_1 */
|
#endif /* #if (NR_CPUS) <= RCU_FANOUT_1 */
|
||||||
@ -252,7 +248,9 @@ struct rcu_node {
|
|||||||
/* Counts of upcoming no-CB GP requests. */
|
/* Counts of upcoming no-CB GP requests. */
|
||||||
raw_spinlock_t fqslock ____cacheline_internodealigned_in_smp;
|
raw_spinlock_t fqslock ____cacheline_internodealigned_in_smp;
|
||||||
|
|
||||||
struct mutex exp_funnel_mutex ____cacheline_internodealigned_in_smp;
|
spinlock_t exp_lock ____cacheline_internodealigned_in_smp;
|
||||||
|
unsigned long exp_seq_rq;
|
||||||
|
wait_queue_head_t exp_wq[4];
|
||||||
} ____cacheline_internodealigned_in_smp;
|
} ____cacheline_internodealigned_in_smp;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -387,11 +385,9 @@ struct rcu_data {
|
|||||||
#ifdef CONFIG_RCU_FAST_NO_HZ
|
#ifdef CONFIG_RCU_FAST_NO_HZ
|
||||||
struct rcu_head oom_head;
|
struct rcu_head oom_head;
|
||||||
#endif /* #ifdef CONFIG_RCU_FAST_NO_HZ */
|
#endif /* #ifdef CONFIG_RCU_FAST_NO_HZ */
|
||||||
struct mutex exp_funnel_mutex;
|
atomic_long_t exp_workdone1; /* # done by others #1. */
|
||||||
atomic_long_t expedited_workdone0; /* # done by others #0. */
|
atomic_long_t exp_workdone2; /* # done by others #2. */
|
||||||
atomic_long_t expedited_workdone1; /* # done by others #1. */
|
atomic_long_t exp_workdone3; /* # done by others #3. */
|
||||||
atomic_long_t expedited_workdone2; /* # done by others #2. */
|
|
||||||
atomic_long_t expedited_workdone3; /* # done by others #3. */
|
|
||||||
|
|
||||||
/* 7) Callback offloading. */
|
/* 7) Callback offloading. */
|
||||||
#ifdef CONFIG_RCU_NOCB_CPU
|
#ifdef CONFIG_RCU_NOCB_CPU
|
||||||
@ -505,6 +501,8 @@ struct rcu_state {
|
|||||||
/* _rcu_barrier(). */
|
/* _rcu_barrier(). */
|
||||||
/* End of fields guarded by barrier_mutex. */
|
/* End of fields guarded by barrier_mutex. */
|
||||||
|
|
||||||
|
struct mutex exp_mutex; /* Serialize expedited GP. */
|
||||||
|
struct mutex exp_wake_mutex; /* Serialize wakeup. */
|
||||||
unsigned long expedited_sequence; /* Take a ticket. */
|
unsigned long expedited_sequence; /* Take a ticket. */
|
||||||
atomic_long_t expedited_normal; /* # fallbacks to normal. */
|
atomic_long_t expedited_normal; /* # fallbacks to normal. */
|
||||||
atomic_t expedited_need_qs; /* # CPUs left to check in. */
|
atomic_t expedited_need_qs; /* # CPUs left to check in. */
|
||||||
@ -513,6 +511,8 @@ struct rcu_state {
|
|||||||
|
|
||||||
unsigned long jiffies_force_qs; /* Time at which to invoke */
|
unsigned long jiffies_force_qs; /* Time at which to invoke */
|
||||||
/* force_quiescent_state(). */
|
/* force_quiescent_state(). */
|
||||||
|
unsigned long jiffies_kick_kthreads; /* Time at which to kick */
|
||||||
|
/* kthreads, if configured. */
|
||||||
unsigned long n_force_qs; /* Number of calls to */
|
unsigned long n_force_qs; /* Number of calls to */
|
||||||
/* force_quiescent_state(). */
|
/* force_quiescent_state(). */
|
||||||
unsigned long n_force_qs_lh; /* ~Number of calls leaving */
|
unsigned long n_force_qs_lh; /* ~Number of calls leaving */
|
||||||
|
@ -722,18 +722,22 @@ static void sync_rcu_exp_handler(void *info)
|
|||||||
* synchronize_rcu_expedited - Brute-force RCU grace period
|
* synchronize_rcu_expedited - Brute-force RCU grace period
|
||||||
*
|
*
|
||||||
* Wait for an RCU-preempt grace period, but expedite it. The basic
|
* Wait for an RCU-preempt grace period, but expedite it. The basic
|
||||||
* idea is to invoke synchronize_sched_expedited() to push all the tasks to
|
* idea is to IPI all non-idle non-nohz online CPUs. The IPI handler
|
||||||
* the ->blkd_tasks lists and wait for this list to drain. This consumes
|
* checks whether the CPU is in an RCU-preempt critical section, and
|
||||||
* significant time on all CPUs and is unfriendly to real-time workloads,
|
* if so, it sets a flag that causes the outermost rcu_read_unlock()
|
||||||
* so is thus not recommended for any sort of common-case code.
|
* to report the quiescent state. On the other hand, if the CPU is
|
||||||
* In fact, if you are using synchronize_rcu_expedited() in a loop,
|
* not in an RCU read-side critical section, the IPI handler reports
|
||||||
* please restructure your code to batch your updates, and then Use a
|
* the quiescent state immediately.
|
||||||
* single synchronize_rcu() instead.
|
*
|
||||||
|
* Although this is a greate improvement over previous expedited
|
||||||
|
* implementations, it is still unfriendly to real-time workloads, so is
|
||||||
|
* thus not recommended for any sort of common-case code. In fact, if
|
||||||
|
* you are using synchronize_rcu_expedited() in a loop, please restructure
|
||||||
|
* your code to batch your updates, and then Use a single synchronize_rcu()
|
||||||
|
* instead.
|
||||||
*/
|
*/
|
||||||
void synchronize_rcu_expedited(void)
|
void synchronize_rcu_expedited(void)
|
||||||
{
|
{
|
||||||
struct rcu_node *rnp;
|
|
||||||
struct rcu_node *rnp_unlock;
|
|
||||||
struct rcu_state *rsp = rcu_state_p;
|
struct rcu_state *rsp = rcu_state_p;
|
||||||
unsigned long s;
|
unsigned long s;
|
||||||
|
|
||||||
@ -744,23 +748,14 @@ void synchronize_rcu_expedited(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
s = rcu_exp_gp_seq_snap(rsp);
|
s = rcu_exp_gp_seq_snap(rsp);
|
||||||
|
if (exp_funnel_lock(rsp, s))
|
||||||
rnp_unlock = exp_funnel_lock(rsp, s);
|
|
||||||
if (rnp_unlock == NULL)
|
|
||||||
return; /* Someone else did our work for us. */
|
return; /* Someone else did our work for us. */
|
||||||
|
|
||||||
rcu_exp_gp_seq_start(rsp);
|
|
||||||
|
|
||||||
/* Initialize the rcu_node tree in preparation for the wait. */
|
/* Initialize the rcu_node tree in preparation for the wait. */
|
||||||
sync_rcu_exp_select_cpus(rsp, sync_rcu_exp_handler);
|
sync_rcu_exp_select_cpus(rsp, sync_rcu_exp_handler);
|
||||||
|
|
||||||
/* Wait for snapshotted ->blkd_tasks lists to drain. */
|
/* Wait for ->blkd_tasks lists to drain, then wake everyone up. */
|
||||||
rnp = rcu_get_root(rsp);
|
rcu_exp_wait_wake(rsp, s);
|
||||||
synchronize_sched_expedited_wait(rsp);
|
|
||||||
|
|
||||||
/* Clean up and exit. */
|
|
||||||
rcu_exp_gp_seq_end(rsp);
|
|
||||||
mutex_unlock(&rnp_unlock->exp_funnel_mutex);
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(synchronize_rcu_expedited);
|
EXPORT_SYMBOL_GPL(synchronize_rcu_expedited);
|
||||||
|
|
||||||
|
@ -185,17 +185,16 @@ static int show_rcuexp(struct seq_file *m, void *v)
|
|||||||
int cpu;
|
int cpu;
|
||||||
struct rcu_state *rsp = (struct rcu_state *)m->private;
|
struct rcu_state *rsp = (struct rcu_state *)m->private;
|
||||||
struct rcu_data *rdp;
|
struct rcu_data *rdp;
|
||||||
unsigned long s0 = 0, s1 = 0, s2 = 0, s3 = 0;
|
unsigned long s1 = 0, s2 = 0, s3 = 0;
|
||||||
|
|
||||||
for_each_possible_cpu(cpu) {
|
for_each_possible_cpu(cpu) {
|
||||||
rdp = per_cpu_ptr(rsp->rda, cpu);
|
rdp = per_cpu_ptr(rsp->rda, cpu);
|
||||||
s0 += atomic_long_read(&rdp->expedited_workdone0);
|
s1 += atomic_long_read(&rdp->exp_workdone1);
|
||||||
s1 += atomic_long_read(&rdp->expedited_workdone1);
|
s2 += atomic_long_read(&rdp->exp_workdone2);
|
||||||
s2 += atomic_long_read(&rdp->expedited_workdone2);
|
s3 += atomic_long_read(&rdp->exp_workdone3);
|
||||||
s3 += atomic_long_read(&rdp->expedited_workdone3);
|
|
||||||
}
|
}
|
||||||
seq_printf(m, "s=%lu wd0=%lu wd1=%lu wd2=%lu wd3=%lu n=%lu enq=%d sc=%lu\n",
|
seq_printf(m, "s=%lu wd1=%lu wd2=%lu wd3=%lu n=%lu enq=%d sc=%lu\n",
|
||||||
rsp->expedited_sequence, s0, s1, s2, s3,
|
rsp->expedited_sequence, s1, s2, s3,
|
||||||
atomic_long_read(&rsp->expedited_normal),
|
atomic_long_read(&rsp->expedited_normal),
|
||||||
atomic_read(&rsp->expedited_need_qs),
|
atomic_read(&rsp->expedited_need_qs),
|
||||||
rsp->expedited_sequence / 2);
|
rsp->expedited_sequence / 2);
|
||||||
|
@ -67,7 +67,7 @@ static int rcu_normal_after_boot;
|
|||||||
module_param(rcu_normal_after_boot, int, 0);
|
module_param(rcu_normal_after_boot, int, 0);
|
||||||
#endif /* #ifndef CONFIG_TINY_RCU */
|
#endif /* #ifndef CONFIG_TINY_RCU */
|
||||||
|
|
||||||
#if defined(CONFIG_DEBUG_LOCK_ALLOC) && defined(CONFIG_PREEMPT_COUNT)
|
#ifdef CONFIG_DEBUG_LOCK_ALLOC
|
||||||
/**
|
/**
|
||||||
* rcu_read_lock_sched_held() - might we be in RCU-sched read-side critical section?
|
* rcu_read_lock_sched_held() - might we be in RCU-sched read-side critical section?
|
||||||
*
|
*
|
||||||
@ -111,7 +111,7 @@ int rcu_read_lock_sched_held(void)
|
|||||||
return 0;
|
return 0;
|
||||||
if (debug_locks)
|
if (debug_locks)
|
||||||
lockdep_opinion = lock_is_held(&rcu_sched_lock_map);
|
lockdep_opinion = lock_is_held(&rcu_sched_lock_map);
|
||||||
return lockdep_opinion || preempt_count() != 0 || irqs_disabled();
|
return lockdep_opinion || !preemptible();
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(rcu_read_lock_sched_held);
|
EXPORT_SYMBOL(rcu_read_lock_sched_held);
|
||||||
#endif
|
#endif
|
||||||
|
@ -451,6 +451,7 @@ static int torture_shutdown(void *arg)
|
|||||||
torture_shutdown_hook();
|
torture_shutdown_hook();
|
||||||
else
|
else
|
||||||
VERBOSE_TOROUT_STRING("No torture_shutdown_hook(), skipping.");
|
VERBOSE_TOROUT_STRING("No torture_shutdown_hook(), skipping.");
|
||||||
|
ftrace_dump(DUMP_ALL);
|
||||||
kernel_power_off(); /* Shut down the system. */
|
kernel_power_off(); /* Shut down the system. */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -602,8 +603,9 @@ bool torture_init_begin(char *ttype, bool v, int *runnable)
|
|||||||
{
|
{
|
||||||
mutex_lock(&fullstop_mutex);
|
mutex_lock(&fullstop_mutex);
|
||||||
if (torture_type != NULL) {
|
if (torture_type != NULL) {
|
||||||
pr_alert("torture_init_begin: refusing %s init: %s running",
|
pr_alert("torture_init_begin: Refusing %s init: %s running.\n",
|
||||||
ttype, torture_type);
|
ttype, torture_type);
|
||||||
|
pr_alert("torture_init_begin: One torture test at a time!\n");
|
||||||
mutex_unlock(&fullstop_mutex);
|
mutex_unlock(&fullstop_mutex);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -1289,6 +1289,39 @@ config TORTURE_TEST
|
|||||||
tristate
|
tristate
|
||||||
default n
|
default n
|
||||||
|
|
||||||
|
config RCU_PERF_TEST
|
||||||
|
tristate "performance tests for RCU"
|
||||||
|
depends on DEBUG_KERNEL
|
||||||
|
select TORTURE_TEST
|
||||||
|
select SRCU
|
||||||
|
select TASKS_RCU
|
||||||
|
default n
|
||||||
|
help
|
||||||
|
This option provides a kernel module that runs performance
|
||||||
|
tests on the RCU infrastructure. The kernel module may be built
|
||||||
|
after the fact on the running kernel to be tested, if desired.
|
||||||
|
|
||||||
|
Say Y here if you want RCU performance tests to be built into
|
||||||
|
the kernel.
|
||||||
|
Say M if you want the RCU performance tests to build as a module.
|
||||||
|
Say N if you are unsure.
|
||||||
|
|
||||||
|
config RCU_PERF_TEST_RUNNABLE
|
||||||
|
bool "performance tests for RCU runnable by default"
|
||||||
|
depends on RCU_PERF_TEST = y
|
||||||
|
default n
|
||||||
|
help
|
||||||
|
This option provides a way to build the RCU performance tests
|
||||||
|
directly into the kernel without them starting up at boot time.
|
||||||
|
You can use /sys/module to manually override this setting.
|
||||||
|
This /proc file is available only when the RCU performance
|
||||||
|
tests have been built into the kernel.
|
||||||
|
|
||||||
|
Say Y here if you want the RCU performance tests to start during
|
||||||
|
boot (you probably don't).
|
||||||
|
Say N here if you want the RCU performance tests to start only
|
||||||
|
after being manually enabled via /sys/module.
|
||||||
|
|
||||||
config RCU_TORTURE_TEST
|
config RCU_TORTURE_TEST
|
||||||
tristate "torture tests for RCU"
|
tristate "torture tests for RCU"
|
||||||
depends on DEBUG_KERNEL
|
depends on DEBUG_KERNEL
|
||||||
|
90
tools/testing/selftests/rcutorture/bin/jitter.sh
Executable file
@ -0,0 +1,90 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# Alternate sleeping and spinning on randomly selected CPUs. The purpose
|
||||||
|
# of this script is to inflict random OS jitter on a concurrently running
|
||||||
|
# test.
|
||||||
|
#
|
||||||
|
# Usage: jitter.sh me duration [ sleepmax [ spinmax ] ]
|
||||||
|
#
|
||||||
|
# me: Random-number-generator seed salt.
|
||||||
|
# duration: Time to run in seconds.
|
||||||
|
# sleepmax: Maximum microseconds to sleep, defaults to one second.
|
||||||
|
# spinmax: Maximum microseconds to spin, defaults to one millisecond.
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, you can access it online at
|
||||||
|
# http://www.gnu.org/licenses/gpl-2.0.html.
|
||||||
|
#
|
||||||
|
# Copyright (C) IBM Corporation, 2016
|
||||||
|
#
|
||||||
|
# Authors: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
me=$(($1 * 1000))
|
||||||
|
duration=$2
|
||||||
|
sleepmax=${3-1000000}
|
||||||
|
spinmax=${4-1000}
|
||||||
|
|
||||||
|
n=1
|
||||||
|
|
||||||
|
starttime=`awk 'BEGIN { print systime(); }' < /dev/null`
|
||||||
|
|
||||||
|
while :
|
||||||
|
do
|
||||||
|
# Check for done.
|
||||||
|
t=`awk -v s=$starttime 'BEGIN { print systime() - s; }' < /dev/null`
|
||||||
|
if test "$t" -gt "$duration"
|
||||||
|
then
|
||||||
|
exit 0;
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Set affinity to randomly selected CPU
|
||||||
|
cpus=`ls /sys/devices/system/cpu/*/online |
|
||||||
|
sed -e 's,/[^/]*$,,' -e 's/^[^0-9]*//' |
|
||||||
|
grep -v '^0*$'`
|
||||||
|
cpumask=`awk -v cpus="$cpus" -v me=$me -v n=$n 'BEGIN {
|
||||||
|
srand(n + me + systime());
|
||||||
|
ncpus = split(cpus, ca);
|
||||||
|
curcpu = ca[int(rand() * ncpus + 1)];
|
||||||
|
mask = lshift(1, curcpu);
|
||||||
|
if (mask + 0 <= 0)
|
||||||
|
mask = 1;
|
||||||
|
printf("%#x\n", mask);
|
||||||
|
}' < /dev/null`
|
||||||
|
n=$(($n+1))
|
||||||
|
if ! taskset -p $cpumask $$ > /dev/null 2>&1
|
||||||
|
then
|
||||||
|
echo taskset failure: '"taskset -p ' $cpumask $$ '"'
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Sleep a random duration
|
||||||
|
sleeptime=`awk -v me=$me -v n=$n -v sleepmax=$sleepmax 'BEGIN {
|
||||||
|
srand(n + me + systime());
|
||||||
|
printf("%06d", int(rand() * sleepmax));
|
||||||
|
}' < /dev/null`
|
||||||
|
n=$(($n+1))
|
||||||
|
sleep .$sleeptime
|
||||||
|
|
||||||
|
# Spin a random duration
|
||||||
|
limit=`awk -v me=$me -v n=$n -v spinmax=$spinmax 'BEGIN {
|
||||||
|
srand(n + me + systime());
|
||||||
|
printf("%06d", int(rand() * spinmax));
|
||||||
|
}' < /dev/null`
|
||||||
|
n=$(($n+1))
|
||||||
|
for i in {1..$limit}
|
||||||
|
do
|
||||||
|
echo > /dev/null
|
||||||
|
done
|
||||||
|
done
|
||||||
|
|
||||||
|
exit 1
|
121
tools/testing/selftests/rcutorture/bin/kvm-recheck-rcuperf-ftrace.sh
Executable file
@ -0,0 +1,121 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# Analyze a given results directory for rcuperf performance measurements,
|
||||||
|
# looking for ftrace data. Exits with 0 if data was found, analyzed, and
|
||||||
|
# printed. Intended to be invoked from kvm-recheck-rcuperf.sh after
|
||||||
|
# argument checking.
|
||||||
|
#
|
||||||
|
# Usage: kvm-recheck-rcuperf-ftrace.sh resdir
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, you can access it online at
|
||||||
|
# http://www.gnu.org/licenses/gpl-2.0.html.
|
||||||
|
#
|
||||||
|
# Copyright (C) IBM Corporation, 2016
|
||||||
|
#
|
||||||
|
# Authors: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
i="$1"
|
||||||
|
. tools/testing/selftests/rcutorture/bin/functions.sh
|
||||||
|
|
||||||
|
if test "`grep -c 'rcu_exp_grace_period.*start' < $i/console.log`" -lt 100
|
||||||
|
then
|
||||||
|
exit 10
|
||||||
|
fi
|
||||||
|
|
||||||
|
sed -e 's/^\[[^]]*]//' < $i/console.log |
|
||||||
|
grep 'us : rcu_exp_grace_period' |
|
||||||
|
sed -e 's/us : / : /' |
|
||||||
|
tr -d '\015' |
|
||||||
|
awk '
|
||||||
|
$8 == "start" {
|
||||||
|
if (starttask != "")
|
||||||
|
nlost++;
|
||||||
|
starttask = $1;
|
||||||
|
starttime = $3;
|
||||||
|
startseq = $7;
|
||||||
|
}
|
||||||
|
|
||||||
|
$8 == "end" {
|
||||||
|
if (starttask == $1 && startseq == $7) {
|
||||||
|
curgpdur = $3 - starttime;
|
||||||
|
gptimes[++n] = curgpdur;
|
||||||
|
gptaskcnt[starttask]++;
|
||||||
|
sum += curgpdur;
|
||||||
|
if (curgpdur > 1000)
|
||||||
|
print "Long GP " starttime "us to " $3 "us (" curgpdur "us)";
|
||||||
|
starttask = "";
|
||||||
|
} else {
|
||||||
|
# Lost a message or some such, reset.
|
||||||
|
starttask = "";
|
||||||
|
nlost++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$8 == "done" {
|
||||||
|
piggybackcnt[$1]++;
|
||||||
|
}
|
||||||
|
|
||||||
|
END {
|
||||||
|
newNR = asort(gptimes);
|
||||||
|
if (newNR <= 0) {
|
||||||
|
print "No ftrace records found???"
|
||||||
|
exit 10;
|
||||||
|
}
|
||||||
|
pct50 = int(newNR * 50 / 100);
|
||||||
|
if (pct50 < 1)
|
||||||
|
pct50 = 1;
|
||||||
|
pct90 = int(newNR * 90 / 100);
|
||||||
|
if (pct90 < 1)
|
||||||
|
pct90 = 1;
|
||||||
|
pct99 = int(newNR * 99 / 100);
|
||||||
|
if (pct99 < 1)
|
||||||
|
pct99 = 1;
|
||||||
|
div = 10 ** int(log(gptimes[pct90]) / log(10) + .5) / 100;
|
||||||
|
print "Histogram bucket size: " div;
|
||||||
|
last = gptimes[1] - 10;
|
||||||
|
count = 0;
|
||||||
|
for (i = 1; i <= newNR; i++) {
|
||||||
|
current = div * int(gptimes[i] / div);
|
||||||
|
if (last == current) {
|
||||||
|
count++;
|
||||||
|
} else {
|
||||||
|
if (count > 0)
|
||||||
|
print last, count;
|
||||||
|
count = 1;
|
||||||
|
last = current;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (count > 0)
|
||||||
|
print last, count;
|
||||||
|
print "Distribution of grace periods across tasks:";
|
||||||
|
for (i in gptaskcnt) {
|
||||||
|
print "\t" i, gptaskcnt[i];
|
||||||
|
nbatches += gptaskcnt[i];
|
||||||
|
}
|
||||||
|
ngps = nbatches;
|
||||||
|
print "Distribution of piggybacking across tasks:";
|
||||||
|
for (i in piggybackcnt) {
|
||||||
|
print "\t" i, piggybackcnt[i];
|
||||||
|
ngps += piggybackcnt[i];
|
||||||
|
}
|
||||||
|
print "Average grace-period duration: " sum / newNR " microseconds";
|
||||||
|
print "Minimum grace-period duration: " gptimes[1];
|
||||||
|
print "50th percentile grace-period duration: " gptimes[pct50];
|
||||||
|
print "90th percentile grace-period duration: " gptimes[pct90];
|
||||||
|
print "99th percentile grace-period duration: " gptimes[pct99];
|
||||||
|
print "Maximum grace-period duration: " gptimes[newNR];
|
||||||
|
print "Grace periods: " ngps + 0 " Batches: " nbatches + 0 " Ratio: " ngps / nbatches " Lost: " nlost + 0;
|
||||||
|
print "Computed from ftrace data.";
|
||||||
|
}'
|
||||||
|
exit 0
|
96
tools/testing/selftests/rcutorture/bin/kvm-recheck-rcuperf.sh
Executable file
@ -0,0 +1,96 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# Analyze a given results directory for rcuperf performance measurements.
|
||||||
|
#
|
||||||
|
# Usage: kvm-recheck-rcuperf.sh resdir
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, you can access it online at
|
||||||
|
# http://www.gnu.org/licenses/gpl-2.0.html.
|
||||||
|
#
|
||||||
|
# Copyright (C) IBM Corporation, 2016
|
||||||
|
#
|
||||||
|
# Authors: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
i="$1"
|
||||||
|
if test -d $i
|
||||||
|
then
|
||||||
|
:
|
||||||
|
else
|
||||||
|
echo Unreadable results directory: $i
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
PATH=`pwd`/tools/testing/selftests/rcutorture/bin:$PATH; export PATH
|
||||||
|
. tools/testing/selftests/rcutorture/bin/functions.sh
|
||||||
|
|
||||||
|
if kvm-recheck-rcuperf-ftrace.sh $i
|
||||||
|
then
|
||||||
|
# ftrace data was successfully analyzed, call it good!
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
configfile=`echo $i | sed -e 's/^.*\///'`
|
||||||
|
|
||||||
|
sed -e 's/^\[[^]]*]//' < $i/console.log |
|
||||||
|
awk '
|
||||||
|
/-perf: .* gps: .* batches:/ {
|
||||||
|
ngps = $9;
|
||||||
|
nbatches = $11;
|
||||||
|
}
|
||||||
|
|
||||||
|
/-perf: .*writer-duration/ {
|
||||||
|
gptimes[++n] = $5 / 1000.;
|
||||||
|
sum += $5 / 1000.;
|
||||||
|
}
|
||||||
|
|
||||||
|
END {
|
||||||
|
newNR = asort(gptimes);
|
||||||
|
if (newNR <= 0) {
|
||||||
|
print "No rcuperf records found???"
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
pct50 = int(newNR * 50 / 100);
|
||||||
|
if (pct50 < 1)
|
||||||
|
pct50 = 1;
|
||||||
|
pct90 = int(newNR * 90 / 100);
|
||||||
|
if (pct90 < 1)
|
||||||
|
pct90 = 1;
|
||||||
|
pct99 = int(newNR * 99 / 100);
|
||||||
|
if (pct99 < 1)
|
||||||
|
pct99 = 1;
|
||||||
|
div = 10 ** int(log(gptimes[pct90]) / log(10) + .5) / 100;
|
||||||
|
print "Histogram bucket size: " div;
|
||||||
|
last = gptimes[1] - 10;
|
||||||
|
count = 0;
|
||||||
|
for (i = 1; i <= newNR; i++) {
|
||||||
|
current = div * int(gptimes[i] / div);
|
||||||
|
if (last == current) {
|
||||||
|
count++;
|
||||||
|
} else {
|
||||||
|
if (count > 0)
|
||||||
|
print last, count;
|
||||||
|
count = 1;
|
||||||
|
last = current;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (count > 0)
|
||||||
|
print last, count;
|
||||||
|
print "Average grace-period duration: " sum / newNR " microseconds";
|
||||||
|
print "Minimum grace-period duration: " gptimes[1];
|
||||||
|
print "50th percentile grace-period duration: " gptimes[pct50];
|
||||||
|
print "90th percentile grace-period duration: " gptimes[pct90];
|
||||||
|
print "99th percentile grace-period duration: " gptimes[pct99];
|
||||||
|
print "Maximum grace-period duration: " gptimes[newNR];
|
||||||
|
print "Grace periods: " ngps + 0 " Batches: " nbatches + 0 " Ratio: " ngps / nbatches;
|
||||||
|
print "Computed from rcuperf printk output.";
|
||||||
|
}'
|
@ -48,7 +48,10 @@ do
|
|||||||
cat $i/Make.oldconfig.err
|
cat $i/Make.oldconfig.err
|
||||||
fi
|
fi
|
||||||
parse-build.sh $i/Make.out $configfile
|
parse-build.sh $i/Make.out $configfile
|
||||||
|
if test "$TORTURE_SUITE" != rcuperf
|
||||||
|
then
|
||||||
parse-torture.sh $i/console.log $configfile
|
parse-torture.sh $i/console.log $configfile
|
||||||
|
fi
|
||||||
parse-console.sh $i/console.log $configfile
|
parse-console.sh $i/console.log $configfile
|
||||||
if test -r $i/Warnings
|
if test -r $i/Warnings
|
||||||
then
|
then
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
# Execute this in the source tree. Do not run it as a background task
|
# Execute this in the source tree. Do not run it as a background task
|
||||||
# because qemu does not seem to like that much.
|
# because qemu does not seem to like that much.
|
||||||
#
|
#
|
||||||
# Usage: kvm-test-1-run.sh config builddir resdir minutes qemu-args boot_args
|
# Usage: kvm-test-1-run.sh config builddir resdir seconds qemu-args boot_args
|
||||||
#
|
#
|
||||||
# qemu-args defaults to "-enable-kvm -soundhw pcspk -nographic", along with
|
# qemu-args defaults to "-enable-kvm -soundhw pcspk -nographic", along with
|
||||||
# arguments specifying the number of CPUs and other
|
# arguments specifying the number of CPUs and other
|
||||||
@ -91,25 +91,33 @@ fi
|
|||||||
# CONFIG_PCMCIA=n
|
# CONFIG_PCMCIA=n
|
||||||
# CONFIG_CARDBUS=n
|
# CONFIG_CARDBUS=n
|
||||||
# CONFIG_YENTA=n
|
# CONFIG_YENTA=n
|
||||||
if kvm-build.sh $config_template $builddir $T
|
base_resdir=`echo $resdir | sed -e 's/\.[0-9]\+$//'`
|
||||||
|
if test "$base_resdir" != "$resdir" -a -f $base_resdir/bzImage -a -f $base_resdir/vmlinux
|
||||||
then
|
then
|
||||||
|
# Rerunning previous test, so use that test's kernel.
|
||||||
|
QEMU="`identify_qemu $base_resdir/vmlinux`"
|
||||||
|
KERNEL=$base_resdir/bzImage
|
||||||
|
ln -s $base_resdir/Make*.out $resdir # for kvm-recheck.sh
|
||||||
|
ln -s $base_resdir/.config $resdir # for kvm-recheck.sh
|
||||||
|
elif kvm-build.sh $config_template $builddir $T
|
||||||
|
then
|
||||||
|
# Had to build a kernel for this test.
|
||||||
QEMU="`identify_qemu $builddir/vmlinux`"
|
QEMU="`identify_qemu $builddir/vmlinux`"
|
||||||
BOOT_IMAGE="`identify_boot_image $QEMU`"
|
BOOT_IMAGE="`identify_boot_image $QEMU`"
|
||||||
cp $builddir/Make*.out $resdir
|
cp $builddir/Make*.out $resdir
|
||||||
|
cp $builddir/vmlinux $resdir
|
||||||
cp $builddir/.config $resdir
|
cp $builddir/.config $resdir
|
||||||
if test -n "$BOOT_IMAGE"
|
if test -n "$BOOT_IMAGE"
|
||||||
then
|
then
|
||||||
cp $builddir/$BOOT_IMAGE $resdir
|
cp $builddir/$BOOT_IMAGE $resdir
|
||||||
|
KERNEL=$resdir/bzImage
|
||||||
else
|
else
|
||||||
echo No identifiable boot image, not running KVM, see $resdir.
|
echo No identifiable boot image, not running KVM, see $resdir.
|
||||||
echo Do the torture scripts know about your architecture?
|
echo Do the torture scripts know about your architecture?
|
||||||
fi
|
fi
|
||||||
parse-build.sh $resdir/Make.out $title
|
parse-build.sh $resdir/Make.out $title
|
||||||
if test -f $builddir.wait
|
|
||||||
then
|
|
||||||
mv $builddir.wait $builddir.ready
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
|
# Build failed.
|
||||||
cp $builddir/Make*.out $resdir
|
cp $builddir/Make*.out $resdir
|
||||||
cp $builddir/.config $resdir || :
|
cp $builddir/.config $resdir || :
|
||||||
echo Build failed, not running KVM, see $resdir.
|
echo Build failed, not running KVM, see $resdir.
|
||||||
@ -119,12 +127,15 @@ else
|
|||||||
fi
|
fi
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
if test -f $builddir.wait
|
||||||
|
then
|
||||||
|
mv $builddir.wait $builddir.ready
|
||||||
|
fi
|
||||||
while test -f $builddir.ready
|
while test -f $builddir.ready
|
||||||
do
|
do
|
||||||
sleep 1
|
sleep 1
|
||||||
done
|
done
|
||||||
minutes=$4
|
seconds=$4
|
||||||
seconds=$(($minutes * 60))
|
|
||||||
qemu_args=$5
|
qemu_args=$5
|
||||||
boot_args=$6
|
boot_args=$6
|
||||||
|
|
||||||
@ -167,15 +178,26 @@ then
|
|||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
echo "NOTE: $QEMU either did not run or was interactive" > $resdir/console.log
|
echo "NOTE: $QEMU either did not run or was interactive" > $resdir/console.log
|
||||||
echo $QEMU $qemu_args -m 512 -kernel $resdir/bzImage -append \"$qemu_append $boot_args\" > $resdir/qemu-cmd
|
echo $QEMU $qemu_args -m 512 -kernel $KERNEL -append \"$qemu_append $boot_args\" > $resdir/qemu-cmd
|
||||||
( $QEMU $qemu_args -m 512 -kernel $resdir/bzImage -append "$qemu_append $boot_args"; echo $? > $resdir/qemu-retval ) &
|
( $QEMU $qemu_args -m 512 -kernel $KERNEL -append "$qemu_append $boot_args"& echo $! > $resdir/qemu_pid; wait `cat $resdir/qemu_pid`; echo $? > $resdir/qemu-retval ) &
|
||||||
qemu_pid=$!
|
|
||||||
commandcompleted=0
|
commandcompleted=0
|
||||||
echo Monitoring qemu job at pid $qemu_pid
|
sleep 10 # Give qemu's pid a chance to reach the file
|
||||||
|
if test -s "$resdir/qemu_pid"
|
||||||
|
then
|
||||||
|
qemu_pid=`cat "$resdir/qemu_pid"`
|
||||||
|
echo Monitoring qemu job at pid $qemu_pid
|
||||||
|
else
|
||||||
|
qemu_pid=""
|
||||||
|
echo Monitoring qemu job at yet-as-unknown pid
|
||||||
|
fi
|
||||||
while :
|
while :
|
||||||
do
|
do
|
||||||
|
if test -z "$qemu_pid" -a -s "$resdir/qemu_pid"
|
||||||
|
then
|
||||||
|
qemu_pid=`cat "$resdir/qemu_pid"`
|
||||||
|
fi
|
||||||
kruntime=`awk 'BEGIN { print systime() - '"$kstarttime"' }' < /dev/null`
|
kruntime=`awk 'BEGIN { print systime() - '"$kstarttime"' }' < /dev/null`
|
||||||
if kill -0 $qemu_pid > /dev/null 2>&1
|
if test -z "$qemu_pid" || kill -0 "$qemu_pid" > /dev/null 2>&1
|
||||||
then
|
then
|
||||||
if test $kruntime -ge $seconds
|
if test $kruntime -ge $seconds
|
||||||
then
|
then
|
||||||
@ -195,12 +217,16 @@ do
|
|||||||
ps -fp $killpid >> $resdir/Warnings 2>&1
|
ps -fp $killpid >> $resdir/Warnings 2>&1
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
echo ' ---' `date`: Kernel done
|
echo ' ---' `date`: "Kernel done"
|
||||||
fi
|
fi
|
||||||
break
|
break
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
if test $commandcompleted -eq 0
|
if test -z "$qemu_pid" -a -s "$resdir/qemu_pid"
|
||||||
|
then
|
||||||
|
qemu_pid=`cat "$resdir/qemu_pid"`
|
||||||
|
fi
|
||||||
|
if test $commandcompleted -eq 0 -a -n "$qemu_pid"
|
||||||
then
|
then
|
||||||
echo Grace period for qemu job at pid $qemu_pid
|
echo Grace period for qemu job at pid $qemu_pid
|
||||||
while :
|
while :
|
||||||
@ -220,6 +246,9 @@ then
|
|||||||
fi
|
fi
|
||||||
sleep 1
|
sleep 1
|
||||||
done
|
done
|
||||||
|
elif test -z "$qemu_pid"
|
||||||
|
then
|
||||||
|
echo Unknown PID, cannot kill qemu command
|
||||||
fi
|
fi
|
||||||
|
|
||||||
parse-torture.sh $resdir/console.log $title
|
parse-torture.sh $resdir/console.log $title
|
||||||
|
@ -34,7 +34,7 @@ T=/tmp/kvm.sh.$$
|
|||||||
trap 'rm -rf $T' 0
|
trap 'rm -rf $T' 0
|
||||||
mkdir $T
|
mkdir $T
|
||||||
|
|
||||||
dur=30
|
dur=$((30*60))
|
||||||
dryrun=""
|
dryrun=""
|
||||||
KVM="`pwd`/tools/testing/selftests/rcutorture"; export KVM
|
KVM="`pwd`/tools/testing/selftests/rcutorture"; export KVM
|
||||||
PATH=${KVM}/bin:$PATH; export PATH
|
PATH=${KVM}/bin:$PATH; export PATH
|
||||||
@ -48,6 +48,7 @@ resdir=""
|
|||||||
configs=""
|
configs=""
|
||||||
cpus=0
|
cpus=0
|
||||||
ds=`date +%Y.%m.%d-%H:%M:%S`
|
ds=`date +%Y.%m.%d-%H:%M:%S`
|
||||||
|
jitter=0
|
||||||
|
|
||||||
. functions.sh
|
. functions.sh
|
||||||
|
|
||||||
@ -63,6 +64,7 @@ usage () {
|
|||||||
echo " --dryrun sched|script"
|
echo " --dryrun sched|script"
|
||||||
echo " --duration minutes"
|
echo " --duration minutes"
|
||||||
echo " --interactive"
|
echo " --interactive"
|
||||||
|
echo " --jitter N [ maxsleep (us) [ maxspin (us) ] ]"
|
||||||
echo " --kmake-arg kernel-make-arguments"
|
echo " --kmake-arg kernel-make-arguments"
|
||||||
echo " --mac nn:nn:nn:nn:nn:nn"
|
echo " --mac nn:nn:nn:nn:nn:nn"
|
||||||
echo " --no-initrd"
|
echo " --no-initrd"
|
||||||
@ -116,12 +118,17 @@ do
|
|||||||
;;
|
;;
|
||||||
--duration)
|
--duration)
|
||||||
checkarg --duration "(minutes)" $# "$2" '^[0-9]*$' '^error'
|
checkarg --duration "(minutes)" $# "$2" '^[0-9]*$' '^error'
|
||||||
dur=$2
|
dur=$(($2*60))
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
--interactive)
|
--interactive)
|
||||||
TORTURE_QEMU_INTERACTIVE=1; export TORTURE_QEMU_INTERACTIVE
|
TORTURE_QEMU_INTERACTIVE=1; export TORTURE_QEMU_INTERACTIVE
|
||||||
;;
|
;;
|
||||||
|
--jitter)
|
||||||
|
checkarg --jitter "(# threads [ sleep [ spin ] ])" $# "$2" '^-\{,1\}[0-9]\+\( \+[0-9]\+\)\{,2\} *$' '^error$'
|
||||||
|
jitter="$2"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
--kmake-arg)
|
--kmake-arg)
|
||||||
checkarg --kmake-arg "(kernel make arguments)" $# "$2" '.*' '^error$'
|
checkarg --kmake-arg "(kernel make arguments)" $# "$2" '.*' '^error$'
|
||||||
TORTURE_KMAKE_ARG="$2"
|
TORTURE_KMAKE_ARG="$2"
|
||||||
@ -156,7 +163,7 @@ do
|
|||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
--torture)
|
--torture)
|
||||||
checkarg --torture "(suite name)" "$#" "$2" '^\(lock\|rcu\)$' '^--'
|
checkarg --torture "(suite name)" "$#" "$2" '^\(lock\|rcu\|rcuperf\)$' '^--'
|
||||||
TORTURE_SUITE=$2
|
TORTURE_SUITE=$2
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
@ -299,6 +306,7 @@ awk < $T/cfgcpu.pack \
|
|||||||
-v CONFIGDIR="$CONFIGFRAG/" \
|
-v CONFIGDIR="$CONFIGFRAG/" \
|
||||||
-v KVM="$KVM" \
|
-v KVM="$KVM" \
|
||||||
-v ncpus=$cpus \
|
-v ncpus=$cpus \
|
||||||
|
-v jitter="$jitter" \
|
||||||
-v rd=$resdir/$ds/ \
|
-v rd=$resdir/$ds/ \
|
||||||
-v dur=$dur \
|
-v dur=$dur \
|
||||||
-v TORTURE_QEMU_ARG="$TORTURE_QEMU_ARG" \
|
-v TORTURE_QEMU_ARG="$TORTURE_QEMU_ARG" \
|
||||||
@ -359,6 +367,16 @@ function dump(first, pastlast, batchnum)
|
|||||||
print "\techo ----", cfr[j], cpusr[j] ovf ": Starting kernel. `date` >> " rd "/log";
|
print "\techo ----", cfr[j], cpusr[j] ovf ": Starting kernel. `date` >> " rd "/log";
|
||||||
print "fi"
|
print "fi"
|
||||||
}
|
}
|
||||||
|
njitter = 0;
|
||||||
|
split(jitter, ja);
|
||||||
|
if (ja[1] == -1 && ncpus == 0)
|
||||||
|
njitter = 1;
|
||||||
|
else if (ja[1] == -1)
|
||||||
|
njitter = ncpus;
|
||||||
|
else
|
||||||
|
njitter = ja[1];
|
||||||
|
for (j = 0; j < njitter; j++)
|
||||||
|
print "jitter.sh " j " " dur " " ja[2] " " ja[3] "&"
|
||||||
print "wait"
|
print "wait"
|
||||||
print "if test -z \"$TORTURE_BUILDONLY\""
|
print "if test -z \"$TORTURE_BUILDONLY\""
|
||||||
print "then"
|
print "then"
|
||||||
|
@ -14,7 +14,7 @@ CONFIG_HOTPLUG_CPU=n
|
|||||||
CONFIG_SUSPEND=n
|
CONFIG_SUSPEND=n
|
||||||
CONFIG_HIBERNATION=n
|
CONFIG_HIBERNATION=n
|
||||||
CONFIG_RCU_FANOUT=4
|
CONFIG_RCU_FANOUT=4
|
||||||
CONFIG_RCU_FANOUT_LEAF=4
|
CONFIG_RCU_FANOUT_LEAF=3
|
||||||
CONFIG_RCU_NOCB_CPU=n
|
CONFIG_RCU_NOCB_CPU=n
|
||||||
CONFIG_DEBUG_LOCK_ALLOC=n
|
CONFIG_DEBUG_LOCK_ALLOC=n
|
||||||
CONFIG_DEBUG_OBJECTS_RCU_HEAD=n
|
CONFIG_DEBUG_OBJECTS_RCU_HEAD=n
|
||||||
|
@ -1 +1 @@
|
|||||||
rcutorture.torture_type=rcu_bh
|
rcutorture.torture_type=rcu_bh rcutree.rcu_fanout_leaf=4
|
||||||
|
@ -0,0 +1 @@
|
|||||||
|
TREE
|
@ -0,0 +1,2 @@
|
|||||||
|
CONFIG_RCU_PERF_TEST=y
|
||||||
|
CONFIG_PRINTK_TIME=y
|
20
tools/testing/selftests/rcutorture/configs/rcuperf/TREE
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
CONFIG_SMP=y
|
||||||
|
CONFIG_PREEMPT_NONE=n
|
||||||
|
CONFIG_PREEMPT_VOLUNTARY=n
|
||||||
|
CONFIG_PREEMPT=y
|
||||||
|
#CHECK#CONFIG_PREEMPT_RCU=y
|
||||||
|
CONFIG_HZ_PERIODIC=n
|
||||||
|
CONFIG_NO_HZ_IDLE=y
|
||||||
|
CONFIG_NO_HZ_FULL=n
|
||||||
|
CONFIG_RCU_FAST_NO_HZ=n
|
||||||
|
CONFIG_RCU_TRACE=n
|
||||||
|
CONFIG_HOTPLUG_CPU=n
|
||||||
|
CONFIG_SUSPEND=n
|
||||||
|
CONFIG_HIBERNATION=n
|
||||||
|
CONFIG_RCU_NOCB_CPU=n
|
||||||
|
CONFIG_DEBUG_LOCK_ALLOC=n
|
||||||
|
CONFIG_PROVE_LOCKING=n
|
||||||
|
CONFIG_RCU_BOOST=n
|
||||||
|
CONFIG_DEBUG_OBJECTS_RCU_HEAD=n
|
||||||
|
CONFIG_RCU_EXPERT=y
|
||||||
|
CONFIG_RCU_TRACE=y
|
23
tools/testing/selftests/rcutorture/configs/rcuperf/TREE54
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
CONFIG_SMP=y
|
||||||
|
CONFIG_NR_CPUS=54
|
||||||
|
CONFIG_PREEMPT_NONE=n
|
||||||
|
CONFIG_PREEMPT_VOLUNTARY=n
|
||||||
|
CONFIG_PREEMPT=y
|
||||||
|
#CHECK#CONFIG_PREEMPT_RCU=y
|
||||||
|
CONFIG_HZ_PERIODIC=n
|
||||||
|
CONFIG_NO_HZ_IDLE=y
|
||||||
|
CONFIG_NO_HZ_FULL=n
|
||||||
|
CONFIG_RCU_FAST_NO_HZ=n
|
||||||
|
CONFIG_RCU_TRACE=n
|
||||||
|
CONFIG_HOTPLUG_CPU=n
|
||||||
|
CONFIG_SUSPEND=n
|
||||||
|
CONFIG_HIBERNATION=n
|
||||||
|
CONFIG_RCU_FANOUT=3
|
||||||
|
CONFIG_RCU_FANOUT_LEAF=2
|
||||||
|
CONFIG_RCU_NOCB_CPU=n
|
||||||
|
CONFIG_DEBUG_LOCK_ALLOC=n
|
||||||
|
CONFIG_PROVE_LOCKING=n
|
||||||
|
CONFIG_RCU_BOOST=n
|
||||||
|
CONFIG_DEBUG_OBJECTS_RCU_HEAD=n
|
||||||
|
CONFIG_RCU_EXPERT=y
|
||||||
|
CONFIG_RCU_TRACE=y
|
@ -0,0 +1,52 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# Torture-suite-dependent shell functions for the rest of the scripts.
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, you can access it online at
|
||||||
|
# http://www.gnu.org/licenses/gpl-2.0.html.
|
||||||
|
#
|
||||||
|
# Copyright (C) IBM Corporation, 2015
|
||||||
|
#
|
||||||
|
# Authors: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
# rcuperf_param_nreaders bootparam-string
|
||||||
|
#
|
||||||
|
# Adds nreaders rcuperf module parameter if not already specified.
|
||||||
|
rcuperf_param_nreaders () {
|
||||||
|
if ! echo "$1" | grep -q "rcuperf.nreaders"
|
||||||
|
then
|
||||||
|
echo rcuperf.nreaders=-1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# rcuperf_param_nwriters bootparam-string
|
||||||
|
#
|
||||||
|
# Adds nwriters rcuperf module parameter if not already specified.
|
||||||
|
rcuperf_param_nwriters () {
|
||||||
|
if ! echo "$1" | grep -q "rcuperf.nwriters"
|
||||||
|
then
|
||||||
|
echo rcuperf.nwriters=-1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# per_version_boot_params bootparam-string config-file seconds
|
||||||
|
#
|
||||||
|
# Adds per-version torture-module parameters to kernels supporting them.
|
||||||
|
per_version_boot_params () {
|
||||||
|
echo $1 `rcuperf_param_nreaders "$1"` \
|
||||||
|
`rcuperf_param_nwriters "$1"` \
|
||||||
|
rcuperf.perf_runnable=1 \
|
||||||
|
rcuperf.shutdown=1 \
|
||||||
|
rcuperf.verbose=1
|
||||||
|
}
|