Commit 83d1bf2d authored by dpedrett's avatar dpedrett

Update Manifest and add review doc sources.

git-svn-id: http://svn.ohwr.org/vme64x-core/trunk@190 665b4545-5c6b-4c24-801b-41150b02b44b
parent 92f0bc34
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Created with Inkscape (http://www.inkscape.org/) -->
<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="744.09448819"
height="1052.3622047"
id="svg2"
version="1.1"
inkscape:version="0.48.0 r9654"
sodipodi:docname="for_loop.svg"
inkscape:export-filename="/opt/ohwr/vme64x_core/hdl/vme64x-core/rtl/CodeReview_2Nov2012/for_loop.png"
inkscape:export-xdpi="180"
inkscape:export-ydpi="180">
<defs
id="defs4" />
<sodipodi:namedview
id="base"
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1.0"
inkscape:pageopacity="0.0"
inkscape:pageshadow="2"
inkscape:zoom="1.979899"
inkscape:cx="327.68922"
inkscape:cy="933.57312"
inkscape:document-units="px"
inkscape:current-layer="g3992"
showgrid="false"
inkscape:window-width="1366"
inkscape:window-height="691"
inkscape:window-x="0"
inkscape:window-y="24"
inkscape:window-maximized="1" />
<metadata
id="metadata7">
<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>
<g
inkscape:label="Layer 1"
inkscape:groupmode="layer"
id="layer1">
<g
id="g3036"
transform="translate(53.571429,42.225289)">
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path3005"
d="m 68.690373,49.028166 0,68.437834"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3007"
d="m 68.824303,49.36999 21.71828,18.687823"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:transform-center-y="-15.267857"
inkscape:transform-center-x="-10.535714"
inkscape:connector-curvature="0"
id="path3007-3"
d="M 90.546643,98.524 68.82836,117.08555"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3027"
d="m 90.471788,67.715987 0.06313,31.248417"
style="fill:none;stroke:#000000;stroke-width:1.00812888px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
</g>
<g
transform="translate(98.42184,42.225289)"
id="g3036-2">
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path3005-6"
d="m 68.690373,49.028166 0,68.437834"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3007-4"
d="m 68.824303,49.36999 21.71828,18.687823"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:transform-center-y="-15.267857"
inkscape:transform-center-x="-10.535714"
inkscape:connector-curvature="0"
id="path3007-3-1"
d="M 90.546643,98.524 68.82836,117.08555"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3027-2"
d="m 90.471788,67.715987 0.06313,31.248417"
style="fill:none;stroke:#000000;stroke-width:1.00812888px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
</g>
<g
transform="translate(143.27226,42.225289)"
id="g3036-6">
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path3005-8"
d="m 68.690373,49.028166 0,68.437834"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3007-9"
d="m 68.824303,49.36999 21.71828,18.687823"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:transform-center-y="-15.267857"
inkscape:transform-center-x="-10.535714"
inkscape:connector-curvature="0"
id="path3007-3-0"
d="M 90.546643,98.524 68.82836,117.08555"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3027-6"
d="m 90.471788,67.715987 0.06313,31.248417"
style="fill:none;stroke:#000000;stroke-width:1.00812888px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
</g>
<g
transform="translate(188.12266,42.225289)"
id="g3036-26">
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path3005-5"
d="m 68.690373,49.028166 0,68.437834"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3007-2"
d="m 68.824303,49.36999 21.71828,18.687823"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:transform-center-y="-15.267857"
inkscape:transform-center-x="-10.535714"
inkscape:connector-curvature="0"
id="path3007-3-6"
d="M 90.546643,98.524 68.82836,117.08555"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3027-5"
d="m 90.471788,67.715987 0.06313,31.248417"
style="fill:none;stroke:#000000;stroke-width:1.00812888px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
</g>
<g
transform="translate(232.9731,42.225289)"
id="g3036-0">
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path3005-4"
d="m 68.690373,49.028166 0,68.437834"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3007-8"
d="m 68.824303,49.36999 21.71828,18.687823"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:transform-center-y="-15.267857"
inkscape:transform-center-x="-10.535714"
inkscape:connector-curvature="0"
id="path3007-3-7"
d="M 90.546643,98.524 68.82836,117.08555"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3027-0"
d="m 90.471788,67.715987 0.06313,31.248417"
style="fill:none;stroke:#000000;stroke-width:1.00812888px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
</g>
<g
transform="translate(277.82351,42.225289)"
id="g3036-7">
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path3005-9"
d="m 68.690373,49.028166 0,68.437834"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3007-39"
d="m 68.824303,49.36999 21.71828,18.687823"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:transform-center-y="-15.267857"
inkscape:transform-center-x="-10.535714"
inkscape:connector-curvature="0"
id="path3007-3-2"
d="M 90.546643,98.524 68.82836,117.08555"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3027-8"
d="m 90.471788,67.715987 0.06313,31.248417"
style="fill:none;stroke:#000000;stroke-width:1.00812888px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
</g>
<g
transform="translate(322.67392,42.225289)"
id="g3036-78">
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path3005-91"
d="m 68.690373,49.028166 0,68.437834"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3007-5"
d="m 68.824303,49.36999 21.71828,18.687823"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:transform-center-y="-15.267857"
inkscape:transform-center-x="-10.535714"
inkscape:connector-curvature="0"
id="path3007-3-4"
d="M 90.546643,98.524 68.82836,117.08555"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3027-9"
d="m 90.471788,67.715987 0.06313,31.248417"
style="fill:none;stroke:#000000;stroke-width:1.00812888px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
</g>
<g
transform="translate(367.52435,42.225289)"
id="g3036-70">
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path3005-81"
d="m 68.690373,49.028166 0,68.437834"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3007-99"
d="m 68.824303,49.36999 21.71828,18.687823"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:transform-center-y="-15.267857"
inkscape:transform-center-x="-10.535714"
inkscape:connector-curvature="0"
id="path3007-3-78"
d="M 90.546643,98.524 68.82836,117.08555"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3027-25"
d="m 90.471788,67.715987 0.06313,31.248417"
style="fill:none;stroke:#000000;stroke-width:1.00812888px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
</g>
<g
id="g3992">
<path
inkscape:connector-curvature="0"
id="path3930"
d="m 109.61086,107.45402 12.71057,0"
style="fill:none;stroke:#000000;stroke-width:0.75460809px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3930-2"
d="m 155.03432,107.45402 11.66211,0"
style="fill:none;stroke:#000000;stroke-width:0.72281569px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:transform-center-y="0.5"
inkscape:transform-center-x="-2.0616501"
inkscape:connector-curvature="0"
id="path3930-0"
d="m 202.73969,107.36473 8.77817,0.0893"
style="fill:none;stroke:#000000;stroke-width:0.75977755px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
sodipodi:nodetypes="cc" />
<path
inkscape:connector-curvature="0"
id="path3930-5"
d="m 249.71866,107.45402 7.15634,0"
style="fill:none;stroke:#000000;stroke-width:0.56621891px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3930-4"
d="m 293.54228,107.36473 7.97558,0.0893"
style="fill:none;stroke:#000000;stroke-width:0.76505297px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
sodipodi:nodetypes="cc" />
<path
inkscape:connector-curvature="0"
id="path3930-9"
d="m 339.00003,107.45402 7.33926,0"
style="fill:none;stroke:#000000;stroke-width:0.57340956px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3930-6"
d="m 382.79828,107.45402 8.71958,0"
style="fill:none;stroke:#000000;stroke-width:0.62500966px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3930-21"
d="m 430.12778,107.45402 5.85436,0"
style="fill:none;stroke:#000000;stroke-width:0.51212823px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 293.9732,107.40683 0.0893,-22.321442 -41.25,0 -6.69643,-0.08928"
id="path4325-6-2"
inkscape:connector-curvature="0"
sodipodi:nodetypes="cccc" />
<path
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 339.33035,107.49611 0.0893,-22.321437 -41.25,0 -6.69643,-0.08928"
id="path4325-6-0"
inkscape:connector-curvature="0"
sodipodi:nodetypes="cccc" />
<path
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 383.25891,107.5854 0.0893,-22.321441 -41.25,0 -6.69643,-0.08928"
id="path4325-6-24"
inkscape:connector-curvature="0"
sodipodi:nodetypes="cccc" />
<path
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 430.31249,107.67468 0.0893,-22.321436 -41.25,0 -6.69643,-0.08928"
id="path4325-6-6"
inkscape:connector-curvature="0"
sodipodi:nodetypes="cccc" />
<g
id="g3512"
transform="translate(305.06607,186.87822)">
<path
sodipodi:nodetypes="cssscc"
inkscape:connector-curvature="0"
id="path4393"
d="m 78.050366,39.930217 c 0,0 4.266184,0.2065 7.628653,-1.55442 2.544415,-1.33251 4.257867,-4.66042 4.162282,-7.4098 -0.08027,-2.30879 -1.64967,-5.44707 -3.945034,-6.80248 -3.679364,-2.17266 -7.958768,-2.03812 -7.958768,-2.03812 z"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path4395"
d="M 43.690385,36.27499 74.78958,36.40126"
style="fill:none;stroke:#000000;stroke-width:0.95157194px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path4395-0"
d="m 43.815366,25.98406 34.345187,0.12627"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<text
sodipodi:linespacing="125%"
id="text4415"
y="23.143007"
x="14.394673"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
xml:space="preserve"><tspan
style="font-size:8px"
y="23.143007"
x="14.394673"
id="tspan4417"
sodipodi:role="line">ModuleEnable</tspan></text>
<text
sodipodi:linespacing="125%"
id="text4415-0"
y="44.467262"
x="14.093782"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
xml:space="preserve"><tspan
style="font-size:8px"
y="44.467262"
x="14.093782"
id="tspan4417-8"
sodipodi:role="line">InitInProgress</tspan></text>
<path
transform="matrix(0.91026714,0,0,1,12.262227,-19.884564)"
d="m 72.321427,56.201466 c 0,0.739667 -0.799491,1.339285 -1.785714,1.339285 -0.986223,0 -1.785714,-0.599618 -1.785714,-1.339285 0,-0.739667 0.799491,-1.339286 1.785714,-1.339286 0.986223,0 1.785714,0.599619 1.785714,1.339286 z"
sodipodi:ry="1.3392857"
sodipodi:rx="1.7857143"
sodipodi:cy="56.201466"
sodipodi:cx="70.535713"
id="path4440"
style="opacity:0.9;fill:none;stroke:#000000;stroke-width:0.80000001;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
sodipodi:type="arc" />
</g>
<path
style="fill:none;stroke:#000000;stroke-width:1.00942969px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 130.18341,59.286224 0.12627,39.113147"
id="path4613"
inkscape:connector-curvature="0" />
<path
style="fill:none;stroke:#000000;stroke-width:1.00732076px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 175.3246,59.761036 0.12627,38.949883"
id="path4613-6"
inkscape:connector-curvature="0" />
<path
style="fill:none;stroke:#000000;stroke-width:1.00414348px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 220.27639,60.326162 0.12627,38.704554"
id="path4613-7"
inkscape:connector-curvature="0" />
<path
style="fill:none;stroke:#000000;stroke-width:1.01467645px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 265.48072,60.013574 0.12627,39.520795"
id="path4613-8"
inkscape:connector-curvature="0" />
<path
style="fill:none;stroke:#000000;stroke-width:1.01409078px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 310.68505,60.013574 0.12627,39.475197"
id="path4613-0"
inkscape:connector-curvature="0" />
<path
style="fill:none;stroke:#000000;stroke-width:1.01624918px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 355.63683,60.266112 0.12627,39.643411"
id="path4613-1"
inkscape:connector-curvature="0" />
<path
style="fill:none;stroke:#000000;stroke-width:1.02190983px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 400.58862,60.013574 0.12627,40.086276"
id="path4613-3"
inkscape:connector-curvature="0" />
<path
style="fill:none;stroke:#000000;stroke-width:1.01409078px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 445.66668,60.139844 0.12627,39.475191"
id="path4613-82"
inkscape:connector-curvature="0" />
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="110.48543"
y="55.846695"
id="text4737"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4739"
x="110.48543"
y="55.846695"
style="font-size:6px">s_func_sel(0)</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="158.55989"
y="56.534592"
id="text4737-7"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4739-9"
x="158.55989"
y="56.534592"
style="font-size:6px">s_func_sel(1)</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="203.25916"
y="56.787125"
id="text4737-4"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4739-1"
x="203.25916"
y="56.787125"
style="font-size:6px">s_func_sel(2)</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="248.96855"
y="56.534588"
id="text4737-1"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4739-18"
x="248.96855"
y="56.534588"
style="font-size:6px">s_func_sel(3)</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="293.41528"
y="56.408318"
id="text4737-43"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4739-8"
x="293.41528"
y="56.408318"
style="font-size:6px">s_func_sel(4)</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="337.23062"
y="56.155781"
id="text4737-0"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4739-6"
x="337.23062"
y="56.155781"
style="font-size:6px">s_func_sel(5)</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="382.1824"
y="56.155781"
id="text4737-8"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4739-80"
x="382.1824"
y="56.155781"
style="font-size:6px">s_func_sel(6)</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="429.78586"
y="56.408321"
id="text4737-86"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4739-3"
x="429.78586"
y="56.408321"
style="font-size:6px">s_func_sel(7)</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="549.01794"
y="122.01169"
id="text4816"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4818"
x="549.01794"
y="122.01169">CardSel</tspan></text>
<rect
style="opacity:0.90000000000000002;fill:none;stroke:#000000;stroke-width:1.4;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
id="rect4820"
width="65.154839"
height="81.317284"
x="479.31738"
y="112.92032" />
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="481.84277"
y="130.09293"
id="text4840"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4842"
x="481.84277"
y="130.09293">D</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="531.34027"
y="128.57768"
id="text4844"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4846"
x="531.34027"
y="128.57768">Q</tspan></text>
<g
id="g3522"
transform="matrix(0,-1,-1,0,673.30616,666.34192)">
<path
inkscape:connector-curvature="0"
id="path4848"
d="m 504.06612,193.73252 5.05076,-7.07107 5.55584,7.57614"
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
sodipodi:nodetypes="cc"
inkscape:connector-curvature="0"
id="path4850"
d="m 509.11688,210.90511 0.0631,-16.79329"
style="fill:none;stroke:#000000;stroke-width:0.89972264px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
</g>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="461.17645"
y="155.40222"
id="text4852"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4854"
x="461.17645"
y="155.40222"
style="font-size:8px">clk</tspan></text>
<path
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 394.91072,217.89789 113.30357,0.17858 0.0893,-23.83929"
id="path3526"
inkscape:connector-curvature="0"
sodipodi:nodetypes="ccc" />
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="505.40179"
y="192.54076"
id="text3528"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan3530"
x="505.40179"
y="192.54076"
style="font-size:10px">R</tspan></text>
</g>
<g
transform="translate(0.4590705,35.265795)"
id="g3992-7">
<path
inkscape:connector-curvature="0"
id="path3930-213"
d="m 109.61086,107.45402 12.71057,0"
style="fill:none;stroke:#000000;stroke-width:0.75460809px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3930-2-4"
d="m 153.95252,107.38706 12.74391,0.067"
style="fill:none;stroke:#000000;stroke-width:0.72281569px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
sodipodi:nodetypes="cc" />
<path
inkscape:transform-center-y="0.5"
inkscape:transform-center-x="-2.0616501"
inkscape:connector-curvature="0"
id="path3930-0-9"
d="m 198.63255,107.45402 12.88531,0"
style="fill:none;stroke:#000000;stroke-width:0.75977755px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3930-5-4"
d="m 242.94123,107.45402 13.93377,0"
style="fill:none;stroke:#000000;stroke-width:0.79008406px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3930-4-1"
d="m 288.45299,107.45402 13.06487,0"
style="fill:none;stroke:#000000;stroke-width:0.76505297px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3930-9-9"
d="m 333.09833,107.45402 13.24096,0"
style="fill:none;stroke:#000000;stroke-width:0.77019137px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3930-6-5"
d="m 378.28306,107.45402 13.2348,0"
style="fill:none;stroke:#000000;stroke-width:0.77001226px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
<path
inkscape:connector-curvature="0"
id="path3930-21-7"
d="m 424.49477,107.45402 11.48737,0"
style="fill:none;stroke:#000000;stroke-width:0.71737999px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
</g>
<path
style="fill:none;stroke:#000000;stroke-width:0.8;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;stroke-miterlimit:4;stroke-dasharray:none"
d="m 144.07301,122.64303 10.73287,0.12627 -1e-5,19.95051"
id="path4044"
inkscape:connector-curvature="0"
sodipodi:nodetypes="ccc" />
<path
style="fill:none;stroke:#000000;stroke-width:0.80000001;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
d="m 188.77226,122.7693 10.73287,0.12627 -1e-5,19.95051"
id="path4044-5"
inkscape:connector-curvature="0"
sodipodi:nodetypes="ccc" />
<path
style="fill:none;stroke:#000000;stroke-width:0.80000001;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
d="m 233.59778,122.89558 10.16466,0.1894 -1e-5,19.95051"
id="path4044-1"
inkscape:connector-curvature="0"
sodipodi:nodetypes="ccc" />
<path
style="fill:none;stroke:#000000;stroke-width:0.80000001;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
d="m 278.54956,122.89557 10.73287,0.12627 -10e-6,19.95051"
id="path4044-3"
inkscape:connector-curvature="0"
sodipodi:nodetypes="ccc" />
<path
style="fill:none;stroke:#000000;stroke-width:0.80000001;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
d="m 323.24882,122.70617 10.73287,0.12627 -1e-5,19.95051"
id="path4044-7"
inkscape:connector-curvature="0"
sodipodi:nodetypes="ccc" />
<path
style="fill:none;stroke:#000000;stroke-width:0.80000001;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
d="m 368.45314,123.02184 10.73287,0.12627 -1e-5,19.95051"
id="path4044-0"
inkscape:connector-curvature="0"
sodipodi:nodetypes="ccc" />
<path
style="fill:none;stroke:#000000;stroke-width:0.80000001;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
d="m 413.1524,122.95871 12.12183,0.12627 -10e-6,19.95051"
id="path4044-16"
inkscape:connector-curvature="0"
sodipodi:nodetypes="ccc" />
<path
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="M 457.67857,125.21932 478.75,125.39789"
id="path4106"
inkscape:connector-curvature="0" />
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="100.0051"
y="147.2655"
id="text4108"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110"
x="100.0051"
y="147.2655">0</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="100.10059"
y="111.82933"
id="text4108-3"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1"
x="100.10059"
y="111.82933">1</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="124.47032"
y="111.07854"
id="text4108-3-4"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2"
x="124.47032"
y="111.07854"
style="font-size:8px">1</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="124.53771"
y="145.38329"
id="text4108-3-4-0"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2"
x="124.53771"
y="145.38329"
style="font-size:8px">0</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="168.80415"
y="145.50566"
id="text4108-3-4-0-2"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-8"
x="168.80415"
y="145.50566"
style="font-size:8px">0</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="213.62968"
y="145.25311"
id="text4108-3-4-0-8"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-1"
x="213.62968"
y="145.25311"
style="font-size:8px">0</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="259.2128"
y="146.13699"
id="text4108-3-4-0-6"
sodipodi:linespacing="125%"
inkscape:transform-center-x="-4.0406102"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-3"
x="259.2128"
y="146.13699"
style="font-size:8px">0</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="304.16461"
y="146.13699"
id="text4108-3-4-0-9"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-83"
x="304.16461"
y="146.13699"
style="font-size:8px">0</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="348.86383"
y="146.26326"
id="text4108-3-4-0-7"
sodipodi:linespacing="125%"
inkscape:transform-center-x="-3.783392"
inkscape:transform-center-y="1.0101525"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-4"
x="348.86383"
y="146.26326"
style="font-size:8px">0</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="393.56308"
y="146.13699"
id="text4108-3-4-0-23"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-86"
x="393.56308"
y="146.13699"
style="font-size:8px">0</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="438.38861"
y="146.89461"
id="text4108-3-4-0-4"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-7"
x="438.38861"
y="146.89461"
style="font-size:8px">0</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="437.37848"
y="110.90793"
id="text4108-3-4-0-43"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-0"
x="437.37848"
y="110.90793"
style="font-size:8px">1</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="393.74338"
y="111.16438"
id="text4108-3-4-0-43-9"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-0-1"
x="393.74338"
y="111.16438"
style="font-size:8px">1</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="348.03397"
y="111.0381"
id="text4108-3-4-0-43-5"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-0-5"
x="348.03397"
y="111.0381"
style="font-size:8px">1</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="302.82965"
y="111.16438"
id="text4108-3-4-0-43-1"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-0-7"
x="302.82965"
y="111.16438"
style="font-size:8px">1</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="258.63547"
y="110.78558"
id="text4108-3-4-0-43-17"
sodipodi:linespacing="125%"
inkscape:transform-center-x="-3.9143411"
inkscape:transform-center-y="0.75761441"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-0-13"
x="258.63547"
y="110.78558"
style="font-size:8px">1</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="213.1786"
y="110.53303"
id="text4108-3-4-0-43-4"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-0-12"
x="213.1786"
y="110.53303"
style="font-size:8px">1</tspan></text>
<text
xml:space="preserve"
style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"
x="168.22682"
y="110.91183"
id="text4108-3-4-0-43-3"
sodipodi:linespacing="125%"><tspan
sodipodi:role="line"
id="tspan4110-1-2-2-0-8"
x="168.22682"
y="110.91183"
style="font-size:8px">1</tspan></text>
<path
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 155.17857,107.71933 0,-22.678578 -41.25,-0.357143 0,22.500001"
id="path4325"
inkscape:connector-curvature="0" />
<path
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 203.125,107.2729 0.0893,-22.321437 -41.25,0 -6.69643,-0.08928"
id="path4325-6"
inkscape:connector-curvature="0"
sodipodi:nodetypes="cccc" />
<path
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 250.31248,107.40682 0.0893,-22.321433 -41.25,0 -6.69643,-0.08928"
id="path4325-6-8"
inkscape:connector-curvature="0"
sodipodi:nodetypes="cccc" />
<path
style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="m 545.04818,125.45794 21.07143,0.17857"
id="path4106-6"
inkscape:connector-curvature="0" />
</g>
</svg>
\documentclass[a4paper,11pt]{article}
\usepackage[latin1]{inputenc}
\usepackage[T1]{fontenc}
\usepackage[italian,UKenglish]{babel}
%\usepackage[english]{babel}
\usepackage{graphicx}
\begin{document}
\begin{titlepage}
\begin{center}
\huge{\textbf{vme64x-core review 1}}\\
\end{center}
\vspace{17cm}
\begin{flushleft}
Author: Davide Pedretti
\end{flushleft}
\vspace{1cm}
\begin{flushright}
Date: 12/11/2012
\end{flushright}
\end{titlepage}
\newpage
\begin{center}
\LARGE{\textbf{Carlos}}
\end{center}
\begin{itemize}
\item \textit{(m) Reference the AM table (line 75) to a document...}\\
Done. Hex code added as comments.
\item \textit{(?)If all the operations are controlled by DS lines (and others),
is it necessary to place double or triple buffering in the address and data
lines?} \\
Good observation: It is possible place triple buffering only in the control
lines: VME\_GA\_i, VME\_AS\_n\_i, VME\_WRITE\_n\_i, VME\_DS\_n\_i, VME\_RST\_n\_i, VME\_IACK\_n\_i, VME\_IACKIN\_n\_i.\\
Indeed when the vme64x core latches the address and data lines, they should be stable according with the VME specification.
\item \textit{(o) Remove use IEEE.numeric\_std.unsigned; redundant}\\
Done.
\item \textit{(?) VME\_RST\_n\_i what for?}\\
The Power Monitor Module (A20 MEN in our case) should drive this line.
See page 200 VMEbus specification ANSI/IEEE STD1024-1987.
\item \textit{(?) Debug leds should be removed?}\\
Yes. The leds were used during the debug.
\item \textit{(o) In the same process the when others => clause is missing.
Probably it would be better set a deferred output before the case,
so it will always set an output}\\
Assigned a default configuration before the case.\\
Added when others =>.
\item \textit{(o) Coming back to the process in line 243, the previous comment
is applicable. Recommend to preassign before the case to avoid unwanted latches
}.\\
Assigned a default configuration before the case.\\
Added when others =>.
\item \textit{(\_) In the process in line 317, it would be better have records that
which are assigned with predefined record constants. It will reduce the
length and possible errors while assigning values to the outputs}.\\
Done.
\end{itemize}
\newpage
\begin{center}
\LARGE{\textbf{Javier}}
\end{center}
\begin{itemize}
\item VME\_bus.vhd\\
\textit{
There is a comment at line 527 saying:
-- If the S\_FPGA will be provided to a core who drives these lines
-- without
-- erase the A\_FPGA the above mentioned lines should be changed to 'Z'
-- !!!
This should probably change to become a generic so that people can
decide on the behaviour they want. It will then be more visible, not
hidden in the middle of the code. The sentence itself it quite
cryptic. This core should not assume it is used in a board with a
S\_FPGA and a A\_FPGA.}
The comment is related to the SVEC board, so it has been removed from the middle
of the code and
it has been moved on the general description at the beginning of the file.\\
Each VME board plugged in a slot acts as a VME salve module and it has only one
CR/CSR space (conforming with the specification) so only one FPGA at time
must drive the output lines on the VME bus; only one FPGA at time can carry the
vme64x core.\\
In other words, only one FPGA at a time shall answer to the software.\\
\item \textit{VME\_IRQ\_Controller.vhd}
\begin{itemize}
\item \textit{Text diagram in the initial comments not clear regarding state
IACKOUT2}\\
Added comment: \\
If the slave module does not have an interrupt pending (IDLE state) and it
receives a falling edge on the IACKIN, it shall pass the falling edge through the
daisy chain. To obtain this the IACKOUT2 state has been added.
\item \textit{To avoid the time constraint" -> "To respect the timing
constraint}\\
Corrected
\item \textit{Signal naming is not consistent. If the "s\_" prefix is used, it
should be used for all internal signals.}\\
Done. The prefix s\_ is used for all internal signals.
\item \textit{Line 104: "reset" is clearly used as an active-low signal in this
entity, and it is an input port, so its name should be "reset\_n\_i".}\\
Done. reset => reset\_n\_i.
\item \textit{Instantiation of many FlipFlopD components: a single clocked
process would be more compact and easier to understand.}\\
FlipFlopD components replaced by a single clocked process.
\item \textit{Line 247: why should the interrupt controller not be allowed to
go to the IRQ state when VME\_IACKIN\_n\_i='0'?}\\
If VME\_IACKIN\_n\_i='0' and the finite state machine is still in IDLE it means
that we do not have interrupt request pending and this is not the responding
Interrupter and so it passes the falling edge on the IACKOUT on the daisy chain.
As soon as the IACKIN has been released the finite state machine come back to the
IDLE state and it is allowed to go in the IRQ state and request service to the
software.
\item \textit{Line 256: once we have allowed going to the IRQ state even if
VME\_IACKIN\_n\_i is low, we should detect a falling edge of
VME\_IACKIN\_n\_i while in the IRQ state to proceed. A simple detection
of '0' won't work anymore}\\
We go the IRQ state only if VME\_IACKIN\_n\_i is '1'. Once we have allowed
going to the IRQ state we wait until the VME\_IACKIN\_n\_i signal is '0'.
When it is '0' it means that the Interrupt Acknowledge Cycle is in progress and
the finite state machine go in the WAIT\_AS state. At this point we do not need
anymore the detection of '0' on the VME\_IACKIN\_n\_i signal.
I hope I have answered the question.
\item \textit{Line 321: In the IDLE state this block should drive whatever it
gets from IACKIN into IACKOUT. Otherwise it is blocking interrupt
acknowledgement for any cards to the right of the module where it is
instantiated}\\
Indeed when in IDLE, if the VME\_IACKIN\_n\_i is '0' the finite state machine
goes in the IACKOUT2 state where it drives the VME\_IACKOUT\_n\_o.\\
\textit{Driving IACKOUT with AS as is done in other
states looks weird. IACKOUT should be driven by IACKIN when the IACK
chain is not intercepted by this block.}\\
The VMEbus specification tells us that if this is not the responding Interrupter
it shall pass the falling edge of IACKIN* to the next interrupter module in the daisy chain by driving IACKOUT* low.\\
The timing rule 38A (page 183 VMEbus specification) tells us that the Interrupter can take as time it wants before asserting the IACKOUT (because before passing the falling edge the Interrupter has to check if it is the responding Interrupter). Since the timing rule 34 (in the above mentioned page) tells us that the AS* signal is asserted before the IACKIN*, the Interrupter implemented drives the
IACKOUT* with the AS* instead of the IACKIN*. In so doing the Interrupter developed matches the timing rule 35 also at low frequencies.\\ See page 6.
\item \textit{Line 445: these are active-low signals so their value after reset
should be '1', not '0'}.\\
After reset the VME\_IRQ\_n\_o lines are already set to '1'.
\item \textit{I don't understand the whole DS\_LATCH thing. We detect in state
WAIT\_DS that there was some change in the DS lines. This makes us go
to state LATCH\_DS, where the DS lines are latched. Then we check if
VME\_DS\_latched(0) is '0' in the ACK\_INT state. Wouldn't it be simpler
to just wait for DS(0) to become '0'?}\\
In our system the Interrupt Handler supports the data transfer type D08(O) and during the Interrupt Acknowledge Cycle the DS1 line is never asserted (always '1') so it is possible delete the LATCH\_DS state and
delete the further control VME\_DS\_latched(0) = '0' in the ACK\_INT state.
More in general, the type of Interrupter can be also D32. In this case (as shown in the table 31 page 157 VMEbus specification) the Interrupter shall monitor also the DS1* and the LWORD* lines. When I started to implement the Interrupter I did not know in which way the Interrupt Handler was working so I added the LWORD* (never used at the moment) and DS1* lines.
If a D32 interrupter will be used, the finite state machine should be provided with one or more LATCH\_DS states to match the timing rule 13, as done in the VME\_bus component.
The vhdl file has been changed in order to be less confusing. The VME\_DS\_latched(0) = '0' control has been deleted since it was redundant in any case.
\item \textit{Line 467: s\_enable opens the sampling gate for INT\_Req only when
either we have not latched a request (with INT\_Req\_sample) or when
DTACK is being driven low. In this last case, we are in the DTACK
state (until AS goes up) and any INT\_Req pulse will go through the
sampling but in a transient way, i.e. it will not "stick" and we will
lose it. This behavior should be documented so that users of the core
know.}\\
This behavior is undesired. The IRQ\_Controller has been corrected
but in any case interrupt requests coming from the WB application before the Interrupter detects the end of the Interrupt Acknowledge Cycle (AS* rising edge), are lost.
The Interrupter implemented has no queue.
\item \textit{VME\_AS\_n\_i and VME\_DS\_n\_i are passed to two different synchronizer
blocks in parallel. The actual implementation of this will depend on
how clever the synthesis tool is. If it is not clever, it will not
notice it can tap the three-FF synchronizer to get the double-FF
output, and we will have two parallel synchronizers: not good,
especially considering that one of them will not use the I/O FFs. If
these double-clocked signals are really needed, the triple-clocking
block could deliver an extra ouput port for them.}\\
Done.
\end{itemize}
\end{itemize}
\newpage
\begin{center}
\LARGE{\textbf{Pablo}}
\end{center}
\begin{itemize}
\item VME\_IRQ\_Controller.vhd\\
\textit{(m!) As it is already pointed out by Javier the IACKIN-IACKOUT should be looked in more detail. I doubt the interrupt
handler can deal correctly with rule 4.41 (30ns min skew between AS release and IACKOUT release). Notice that this rule applies on the VME connector edge so even with an internal latency of 2 cycles at 10ns you still have all the propagations delays to take care of}\\
Rule 4.41: A partecipating interrupter shall drive IACKOUT* high within this maximum time after the rising edge on AS*.\\
Please note that this rule refers to the interrupter not to the interrupt handler. The figure 55 (page 183 VMEbus specification)
and the related table tell us that the Interrupt Handler does not care the time 35 (so why should we care about that?).\\
However, as you said, if this rule applies on the VME connector edge we are not matching it.
If we drive the IACKOUT* with the IACKIN* as Javier suggested, we do not match this timing rule because of the timing rule 39.
Thus, the only way to always match this rule, regardless of the clock frequency used, is drive the IACKOUT* signal with the AS*
signal not sampled. The metastability will not be a problem in this case because when this signal is outputted it is
already stable.
\item VME\_bus.vhd\\
\textit{(m) It was pointed out in the presentation that the DS toggle could eventually not be properlly detected. In the datasheet it is stated that the skew between this lines can be up to a maximum of 20ns. A single wait state may be not enough if the vme core is clocked at 100MHz. On the other hand it is not necessary if the core is clocked at f<50Mhz. Probably it could be a good idea to use some generic (as carlos sugested) to insert/remove wait states depending on the clocking frequency}\\
Done.\\
Now, in the main finite state machine there are up to 4 LATCH\_DS states selectable with a generic paramiter: g\_clock.
It means that now the timing rule 2.39 page 113 (VMEbus specification ANSI/IEEE STD1014-1987) can be matched up to 200 MHz by
setting the generic g\_clock with the clock period in ns.\\
Adding other LATCH\_DS states the rule 2.39 can be met with frequencies upper to 200 MHz.\\
\begin{itemize}
\item 50 MHz or less: only 1 LATCH\_DS state
\item from 50 MHz to 100 MHz: 2 LATCH\_DS states.
\item from 100 MHz to 150 MHz: 3 LATCH\_DS states.
\item from 150 MHz to 200 MHz: 4 LATCH\_DS states.
\end{itemize}
Please note that in order to meet the timing rule 2.31 (\textit{When using the DTB for two consecutive cycles, the master shall
not drive AS* low until it has been high for this minimum time (30 ns for the slave))} we suggest to use the vme64x core with
frequencies upper than 40 MHz. To match this rule with lower frequencies it is necessary to use different clock domains, and so
a FIFO, inside the vme64x core and sampling the input signals with frequencies upper than 40 MHz.
\end{itemize}
\newpage
\begin{center}
\LARGE{\textbf{Tom}}
\end{center}
\begin{itemize}
\item VME\_bus.vhd\\
\textit{(m) don't comment out code that is not used. Just remove it.}\\
Done
\item VME\_IRQ\_Controller.vhd\\
\textit {(!) line 235: is reset signal active low or high?}\\
As Javier suggested the reset has been renamed reset\_n\_i.
\item VME\_CR\_CSR\_Space.vhd\\
\textit{(m) GADER\_1 loop: please put a single-line comment describing what the generate loop does.}\\
Done.\\
It generates a vector of 8 array (unsigned 32 bits).\\
We need these registers in the decoder.
\item VME\_Access\_Decode.vhd\\
\textit {(o) provide a generic allowing for reduction of device functions. In most cases, we need only 1 A24/A32/D32 BAR.
Decoding and storing BAR configurations takes large percentage of the FPGA resources consumed by the VME core.}\\
I think you can discuss about this point with Julian and David. At the moment I prefer provide the CR/CSR space with all the
functions according with the specification. The aim is to provide you a generic vme64x slave module in agreement with the
specification. You can change the CR/CSR space in order to obtain a custom vme64x slave module at a later time.\\
\textit {(!) process driving cardsel and base\_addr: sequential nonblocking assignments are potentially
dangerous - you are relying on assumption that if any of bits in s\_func\_sel is 1, cardsel (previously set
to 0) will be overwritten by the loop. It's safer to use variables and blocking assignments in such cases.}\\
According to the section 8.7 of the \textit{VHDL for logic synthesis} Third edition, this process is synthesized as shown in the
following figure:\\
\newpage
\begin{figure}[ht]
\begin{center}
\includegraphics[scale=0.70]{for_loop}
\end{center}
\end{figure}
I checked the RTL Schematic after synthesis and, the Base\_Addr and CardSel are synthesized as shown in the above image. \\
I deleted the exit statement that is useless in this case.\\
Thus, the process has not been changed.
\item VME64xCore\_Top.vhd\\
\textit {(\_) Process at lines 530+: I would place it in VME\_bus. This way the top level module will only
act as an interconnect putting together all VME core components.}\\
Done.
The process can be found in the VME\_Wb\_master.vhd component.
\end{itemize}
\newpage
\begin{center}
\LARGE{\textbf{Thedi}}
\end{center}
\begin{itemize}
\item You can find the c\_SIZE constant in the genram\_pkg.\\
\item I developed the code with the Xilinx ISE tool so if you open the code with another editor it may be unaligned.
\item \textit{line 316: this is actually a Moore FSM (outputs depend only on current state)}\\
In the sensitivity list of the project there is also the AS* signal so I wrote: Mealy FSM
\item \textit{I suggest you put the constant values in hex. They are a lot more
readable than binary}.\\
The constant are in binary because each bit corresponds to one AM. These are mask bits.
It is easy to change them in binary.\\
The best thing can be to create a function which takes the AMs as arguments and sets them automatically.
\item \textit{I personally find it a bad idea to define multiple components in the same file.
When I get an entity name in an instantiation, my first instinct is to start
looking for a file with the same name as the entity.}\\
Yes it is not a good idea but also create a file for each small entity it is not nice. These entity are
double flopping, triple flopping, rising and falling edge detection so are all grouped inside one file.\\
\item I corrected some English errors. For sure there are other errors. Apologize my English! :)
\end{itemize}
\newpage
\begin{center}
\LARGE{\textbf{Matthieu}}
\end{center}
\begin{itemize}
\item \textit{Change MBLT endian register name to SWAP configuration register
(or something similar).}\\
Done.\\
MBLT Endian register renamed Endian since it can be used during all the access
modes except during the CR/CSR accesses.
\item \textit{Add a reset output port on core's top level.}\\
In the VME64xCore\_Top's output port there is already a reset\_o signal which is active high and it comes from the software reset bit in the CRS space.
\item I deleted some of the not used signals.
\item \textit{Update the Manifest file.}\\
Done
\item now, you should not see same of the warnings you indicated to me in your
review.
\end{itemize}
\newpage
In the VME64xCore\_Top.vhd file it is possible to find the following generic paramiters:\\
\begin{itemize}
\item g\_clock
\item g\_wb\_data\_width.
\item g\_wb\_addr\_width.
\item g\_cram\_size.
\item g\_BoardID.
\item g\_ManufacturerID.
\item g\_RevisionID.
\item g\_ProgramID.
\end{itemize}
In the VME\_IRQ\_Controller.vhd component, the ACK\_INT state has been renamed CHECK; less confusing\\
During this first review I focused more on the timing problems, not synthesizable processes and so on.
I started from the (!) serious and (m) medium advices and I tried
to answer all the questions. \\
I deleted more or less all the never used signals and processes related to the 2emodes and the buffer not implemented. In so doing the project is less
confusing and clearer.\\
I tested again the vme64x core after making changes and it is still working fine.\\
I cannot see further timing rules violated.\\
\end{document}
......@@ -6,7 +6,7 @@ files = [ "VME64xCore_Top.vhd",
"VME_CR_CSR_Space.vhd",
"VME_CR_pack.vhd",
"VME_CSR_pack.vhd",
"VME_DpBlockRam.vhd",
"VME_CRAM.vhd",
"VME_Funct_Match.vhd",
"VME_Init.vhd",
"VME_IRQ_Controller.vhd",
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment