提交 a64bc3fc 创建 作者: 赵鹏翀's avatar 赵鹏翀

Initial commit

上级
*.cir
*.xml
*.bak
/.vs
\ No newline at end of file
[submodule "8086"]
path = 8086
url = https://zpc@www.codecode.net/engintime/Dream-Logic/Intel-classic-chips/8086.git
[submodule "DAC0832"]
path = DAC0832
url = https://zpc@www.codecode.net/engintime/Dream-Logic/Intel-classic-chips/DAC0832.git
8086 @ 0646239b
Subproject commit 0646239b4d1645f6a0da63d7f4bb3142942e567c
DAC0832 @ b916b418
Subproject commit b916b418cb55c5dd649f96006c5494ab6bd360eb
<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<svg height="1908" version="1.1" width="2697" xmlns="http://www.w3.org/2000/svg">
<rect fill="#80ff80" height="1000" stroke="#800000" stroke-width="1" width="700" x="673" y="662"/>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="673" y="562">DAC0832</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="673" y="612">DAC0832\DAC0832.dlsche</text>
<polygon fill="#ffff80" points="673 762, 698 737, 748 737, 773 762, 748 787, 698 787, 673 762" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="783" y="762">CS</text>
<polygon fill="#ffff80" points="673 862, 698 837, 748 837, 773 862, 748 887, 698 887, 673 862" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="783" y="862">WR1</text>
<polygon fill="#ffff80" points="673 962, 698 937, 748 937, 773 962, 748 987, 698 987, 673 962" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="783" y="962">AGND</text>
<polygon fill="#ffff80" points="673 1062, 698 1037, 748 1037, 773 1062, 748 1087, 698 1087, 673 1062" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="783" y="1062">D3</text>
<polygon fill="#ffff80" points="673 1162, 698 1137, 748 1137, 773 1162, 748 1187, 698 1187, 673 1162" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="783" y="1162">D2</text>
<polygon fill="#ffff80" points="673 1262, 698 1237, 748 1237, 773 1262, 748 1287, 698 1287, 673 1262" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="783" y="1262">D1</text>
<polygon fill="#ffff80" points="673 1362, 698 1337, 748 1337, 773 1362, 748 1387, 698 1387, 673 1362" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="783" y="1362">D0</text>
<polygon fill="#ffff80" points="673 1462, 698 1437, 748 1437, 773 1462, 748 1487, 698 1487, 673 1462" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="783" y="1462">VREF</text>
<polygon fill="#ffff80" points="673 1562, 698 1537, 748 1537, 773 1562, 748 1587, 698 1587, 673 1562" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="783" y="1562">Rfb</text>
<polygon fill="#ffff80" points="1373 762, 1348 737, 1298 737, 1273 762, 1298 787, 1348 787, 1373 762" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1163" y="762">ILE</text>
<polygon fill="#ffff80" points="1373 862, 1348 837, 1298 837, 1273 862, 1298 887, 1348 887, 1373 862" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1163" y="862">WR2</text>
<polygon fill="#ffff80" points="1373 962, 1348 937, 1298 937, 1273 962, 1298 987, 1348 987, 1373 962" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1163" y="962">XFER</text>
<polygon fill="#ffff80" points="1373 1062, 1348 1037, 1298 1037, 1273 1062, 1298 1087, 1348 1087, 1373 1062" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1163" y="1062">D4</text>
<polygon fill="#ffff80" points="1373 1162, 1348 1137, 1298 1137, 1273 1162, 1298 1187, 1348 1187, 1373 1162" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1163" y="1162">D5</text>
<polygon fill="#ffff80" points="1373 1262, 1348 1237, 1298 1237, 1273 1262, 1298 1287, 1348 1287, 1373 1262" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1163" y="1262">D6</text>
<polygon fill="#ffff80" points="1373 1362, 1348 1337, 1298 1337, 1273 1362, 1298 1387, 1348 1387, 1373 1362" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1163" y="1362">D7</text>
<polygon fill="#ffff80" points="1373 1462, 1348 1437, 1298 1437, 1273 1462, 1298 1487, 1348 1487, 1373 1462" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1163" y="1462">Iout2</text>
<polygon fill="#ffff80" points="1373 1562, 1348 1537, 1298 1537, 1273 1562, 1298 1587, 1348 1587, 1373 1562" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1163" y="1562">Iout1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="373" x2="373" y1="962" y2="1012"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="17" font-weight="700" text-anchor="end" x="368" y="1002">0</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="353" x2="353" y1="962" y2="1012"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="17" font-weight="700" text-anchor="end" x="348" y="1002">1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="333" x2="333" y1="962" y2="1012"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="17" font-weight="700" text-anchor="end" x="328" y="1002">2</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="313" x2="313" y1="962" y2="1012"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="17" font-weight="700" text-anchor="end" x="308" y="1002">3</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="293" x2="293" y1="962" y2="1012"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="17" font-weight="700" text-anchor="end" x="288" y="1002">4</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="273" x2="273" y1="962" y2="1012"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="17" font-weight="700" text-anchor="end" x="268" y="1002">5</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="253" x2="253" y1="962" y2="1012"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="17" font-weight="700" text-anchor="end" x="248" y="1002">6</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="233" x2="233" y1="962" y2="1012"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="17" font-weight="700" text-anchor="end" x="228" y="1002">7</text>
<rect fill="#000000" fill-opacity="0.5" height="50" stroke="#a0a0a4" stroke-width="1" width="160" x="223" y="912"/>
<text alignment-baseline="after-edge" fill="#ff0000" font-family="微软雅黑" font-size="30" font-weight="400" text-anchor="start" x="283" y="959">ff</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="401" y="958">1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="15" font-weight="700" text-anchor="start" x="233" y="901">INTER_DIGITAL8</text>
<polyline fill="none" points="673 1362, 373 1362, 373 1012" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="673 1262, 353 1262, 353 1012" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="673 1162, 333 1162, 333 1012" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="673 1062, 313 1062, 313 1012" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="273" y="1012">D5</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="253" y="1012">D6</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="233" y="1012">D7</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="293" y="1012">D4</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="273" x2="373" y1="462" y2="462"/>
<text alignment-baseline="after-edge" fill="#000080" font-family="微软雅黑" font-size="30" font-weight="700" text-anchor="start" x="213" y="483">0</text>
<rect fill="#ffffff" fill-opacity="0.5" height="60" stroke="#800000" stroke-width="5" width="100" x="173" y="432"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="217" y="423">2</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="134" y="574">INTER_DIGITAL</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="174" y="535">Key = 1</text>
<polyline fill="none" points="373 462, 573 462, 573 762, 673 762" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="273" x2="373" y1="612" y2="612"/>
<text alignment-baseline="after-edge" fill="#000080" font-family="微软雅黑" font-size="30" font-weight="700" text-anchor="start" x="213" y="633">0</text>
<rect fill="#ffffff" fill-opacity="0.5" height="60" stroke="#800000" stroke-width="5" width="100" x="173" y="582"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="217" y="573">3</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="134" y="724">INTER_DIGITAL</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="174" y="685">Key = 2</text>
<polyline fill="none" points="673 862, 553 862, 553 612, 373 612" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="473" x2="473" y1="962" y2="862"/>
<polyline fill="none" points="423 962, 523 962" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="443 978, 503 978" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="463 993, 483 993" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="483" y="912"></text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="443" y="1042">GND</text>
<polyline fill="none" points="673 962, 533 962, 533 862, 473 862" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="73" x2="73" y1="1542" y2="1462"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="73" x2="73" y1="1602" y2="1682"/>
<polyline fill="none" points="23 1542, 123 1542" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="53 1562, 93 1562" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="23 1582, 123 1582" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="53 1602, 93 1602" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="124" y="1534">V1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="107" y="1640">DC111</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="153" y="1582">5V</text>
<polyline fill="none" points="73 1462, 673 1462" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="73" x2="73" y1="1782" y2="1682"/>
<polyline fill="none" points="23 1782, 123 1782" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="43 1798, 103 1798" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="63 1813, 83 1813" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="83" y="1732"></text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="43" y="1862">GND</text>
<polyline fill="none" points="1373 762, 1773 762, 1773 562" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1673" x2="1773" y1="562" y2="562"/>
<text alignment-baseline="after-edge" fill="#000080" font-family="微软雅黑" font-size="30" font-weight="700" text-anchor="start" x="1614" y="582">1</text>
<rect fill="#ffffff" fill-opacity="0.5" height="60" stroke="#800000" stroke-width="5" width="100" x="1573" y="532"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1617" y="523">4</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1534" y="674">INTER_DIGITAL</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1574" y="635">Key = 3</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1923" x2="2023" y1="562" y2="562"/>
<text alignment-baseline="after-edge" fill="#000080" font-family="微软雅黑" font-size="30" font-weight="700" text-anchor="start" x="1863" y="583">0</text>
<rect fill="#ffffff" fill-opacity="0.5" height="60" stroke="#800000" stroke-width="5" width="100" x="1823" y="532"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1867" y="523">5</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1784" y="674">INTER_DIGITAL</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1824" y="635">Key = 4</text>
<polyline fill="none" points="1373 862, 2023 862, 2023 562" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="2173" x2="2273" y1="562" y2="562"/>
<text alignment-baseline="after-edge" fill="#000080" font-family="微软雅黑" font-size="30" font-weight="700" text-anchor="start" x="2113" y="583">0</text>
<rect fill="#ffffff" fill-opacity="0.5" height="60" stroke="#800000" stroke-width="5" width="100" x="2073" y="532"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="2117" y="523">6</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="2034" y="674">INTER_DIGITAL</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="2074" y="635">Key = 5</text>
<polyline fill="none" points="1373 962, 2273 962, 2273 562" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1733" x2="1673" y1="1522" y2="1522"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1708" y="1522">2</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1733" x2="1673" y1="1462" y2="1462"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1708" y="1462">1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1833" x2="1893" y1="1492" y2="1492"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1858" y="1492">3</text>
<polygon fill="#fffcf8" fill-opacity="0.5" points="1733 1432, 1733 1552, 1833 1492, 1733 1432" stroke="#000000" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="27" font-weight="700" text-anchor="start" x="1736" y="1539">+</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="27" font-weight="700" text-anchor="start" x="1739" y="1478">-</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1773" y="1452">7</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1733" y="1602">AMP</text>
<polyline fill="none" points="1373 1462, 1473 1462, 1473 1522, 1673 1522" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1373 1562, 1573 1562, 1573 1462, 1673 1462" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="673 1562, 573 1562, 573 1762, 1973 1762, 1973 1492, 1893 1492" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="2623" x2="2623" y1="1812" y2="1712"/>
<polyline fill="none" points="2573 1812, 2673 1812" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="2593 1828, 2653 1828" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="2613 1843, 2633 1843" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="2633" y="1762"></text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="2593" y="1892">GND</text>
<polyline fill="none" points="2613 1492, 2623 1492, 2623 1712" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1623 1522, 1623 1662, 2623 1662" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="200" font-weight="700" text-anchor="start" x="223" y="252">DAC0832功能测试电路</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="2093" x2="1973" y1="1492" y2="1492"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="2493" x2="2613" y1="1492" y2="1492"/>
<rect fill="#808080" height="170" stroke="#808080" stroke-width="5" width="400" x="2093" y="1402"/>
<rect fill="#000000" height="100" stroke="#000000" stroke-width="5" width="250" x="2163" y="1442"/>
<text alignment-baseline="central" fill="#00ff00" font-family="微软雅黑" font-size="35" font-weight="700" text-anchor="end" x="2393" y="1492">4.98047</text>
<text alignment-baseline="after-edge" fill="#00ff00" font-family="微软雅黑" font-size="35" font-weight="700" text-anchor="start" x="2423" y="1512">V</text>
<text alignment-baseline="after-edge" fill="#00ff00" font-family="微软雅黑" font-size="35" font-weight="700" text-anchor="start" x="2133" y="1452">+</text>
<text alignment-baseline="after-edge" fill="#00ff00" font-family="微软雅黑" font-size="35" font-weight="700" text-anchor="start" x="2433" y="1452">-</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="2263" y="1394">U1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="2263" y="1632">V</text>
<circle cx="1623" cy="1522" fill="#0000ff" r="8" stroke="#0000ff" stroke-width="5"/>
<circle cx="2623" cy="1662" fill="#0000ff" r="8" stroke="#0000ff" stroke-width="5"/>
<circle cx="1973" cy="1492" fill="#0000ff" r="8" stroke="#0000ff" stroke-width="5"/>
</svg>
添加文件
<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<svg height="1196" version="1.1" width="2060" xmlns="http://www.w3.org/2000/svg">
<polygon fill="#ffff80" points="36 697, 36 672, 211 672, 236 697, 211 722, 36 722, 36 697" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="36" y="697">A[7..0]</text>
<polyline fill="none" points="1136 717, 936 717, 786 717, 436 717" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1136 747, 936 747, 786 747, 436 747" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1136 777, 936 777, 786 777, 436 777" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="436" y="717">A3</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="436" y="747">A4</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="436" y="777">A5</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1186" x2="1136" y1="817" y2="817"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1232" y="816">G1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1159" y="816">6</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1176" x2="1136" y1="847" y2="847"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1256" y="846">^G2A</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1159" y="848">4</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1176" x2="1136" y1="877" y2="877"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1256" y="876">^G2B</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1158" y="877">5</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1186" x2="1136" y1="717" y2="717"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="middle" x="1213" y="717">A</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1146" y="716">1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1186" x2="1136" y1="747" y2="747"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1219" y="747">B</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1160" y="747">2</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1186" x2="1136" y1="777" y2="777"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="middle" x="1213" y="777">C</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1147" y="777">3</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1346" x2="1386" y1="697" y2="697"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="middle" x="1307" y="694">Y0</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1355" y="697">15</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1346" x2="1386" y1="727" y2="727"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="middle" x="1307" y="724">Y1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1356" y="727">14</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1346" x2="1386" y1="757" y2="757"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="middle" x="1307" y="754">Y2</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1356" y="757">13</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1346" x2="1386" y1="787" y2="787"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="middle" x="1307" y="784">Y3</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1356" y="787">12</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1346" x2="1386" y1="817" y2="817"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="middle" x="1307" y="814">Y4</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1356" y="817">11</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1346" x2="1386" y1="847" y2="847"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="middle" x="1307" y="844">Y5</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1356" y="847">10</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1346" x2="1386" y1="877" y2="877"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="middle" x="1307" y="874">Y6</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1368" y="877">9</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1346" x2="1386" y1="907" y2="907"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1321" y="906">Y7</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1383" y="907">7</text>
<circle cx="1181" cy="877" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<circle cx="1341" cy="757" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<circle cx="1341" cy="788" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<circle cx="1342" cy="817" fill="#ffffff" r="5" stroke="#000000" stroke-width="5"/>
<circle cx="1341" cy="697" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<circle cx="1341" cy="847" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<circle cx="1341" cy="726" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<circle cx="1341" cy="876" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<circle cx="1341" cy="908" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<circle cx="1181" cy="847" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<rect fill="#ffffff" fill-opacity="0.5" height="264" stroke="#000000" stroke-width="5" width="146" x="1188" y="663"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1251" y="654">U1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1189" y="969">74LS138D</text>
<polygon fill="#ffff80" points="36 1147, 36 1122, 161 1122, 186 1147, 161 1172, 36 1172, 36 1147" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="36" y="1147">MIO</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="宋体" font-size="25" font-weight="400" text-anchor="start" x="16" y="1087">低电平表示访问IO端口</text>
<polygon fill="#ffff80" points="36 397, 36 372, 211 372, 236 397, 211 422, 36 422, 36 397" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="36" y="397">WR_OUT</text>
<polygon fill="#ffff80" points="36 547, 36 522, 211 522, 236 547, 211 572, 36 572, 36 547" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="36" y="547">READ_OUT</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="446" x2="386" y1="337" y2="337"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="446" x2="386" y1="397" y2="397"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="576" x2="636" y1="367" y2="367"/>
<path d="M442 321 C 468 360, 441 410, 441 410, 441 410, 441 410, 441 410" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="442 320, 500 320" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="441 410, 499 410" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<path d="M500 320 C 552 320, 576 367, 576 367" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<path d="M498 410 C 554 410, 576 367, 576 367" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="491" y="310">U3</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="479" y="461">OR</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="446" x2="386" y1="487" y2="487"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="446" x2="386" y1="547" y2="547"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="576" x2="636" y1="517" y2="517"/>
<path d="M442 471 C 468 510, 441 560, 441 560, 441 560, 441 560, 441 560" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="442 470, 500 470" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="441 560, 499 560" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<path d="M500 470 C 552 470, 576 517, 576 517" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<path d="M498 560 C 554 560, 576 517, 576 517" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="491" y="460">U4</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="479" y="611">OR</text>
<polyline fill="none" points="386 547, 236 547" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="386 337, 286 337, 286 487" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polygon fill="#ffff80" points="1836 367, 1836 342, 2011 342, 2036 367, 2011 392, 1836 392, 1836 367" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1836" y="367">IOW</text>
<polygon fill="#ffff80" points="1836 517, 1836 492, 2011 492, 2036 517, 2011 542, 1836 542, 1836 517" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1836" y="517">IOR</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="125" font-weight="700" text-anchor="start" x="456" y="167">I/O地址译码单元</text>
<polyline fill="none" points="386 397, 236 397" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polygon fill="#ffff80" points="36 487, 36 462, 211 462, 236 487, 211 512, 36 512, 36 487" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="36" y="487">MIO</text>
<polyline fill="none" points="386 487, 236 487" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="646" x2="586" y1="867" y2="867"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="726" x2="786" y1="867" y2="867"/>
<circle cx="722" cy="867" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<polygon fill="#ffffff" fill-opacity="0.5" points="646 817, 646 917, 716 867, 646 817" stroke="#000000" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="666" y="831">U5</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="646" y="963">NOT</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="436" y="867">A6</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="846" x2="786" y1="867" y2="867"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="846" x2="786" y1="927" y2="927"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="976" x2="1036" y1="897" y2="897"/>
<path d="M924 845 A 47 47 0 1 1 924 938" fill="none" stroke="#000000" stroke-linecap="round" stroke-width="5"/>
<polyline fill="none" points="925 939, 846 939, 846 845, 925 845" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="887" y="839">U6</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="870" y="985">AND</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="436" y="927">A7</text>
<polyline fill="none" points="586 867, 436 867" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="786 927, 436 927" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="386" x2="436" y1="767" y2="717"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="386" x2="436" y1="797" y2="747"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="386" x2="436" y1="827" y2="777"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="386" x2="436" y1="917" y2="867"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="386" x2="436" y1="977" y2="927"/>
<polyline fill="none" points="236 697, 386 697, 386 977" stroke="#000080" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<polyline fill="none" points="1136 817, 1036 817, 1036 897" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="186 1147, 1086 1147, 1086 847, 1136 847" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1386 697, 1836 697" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1386 727, 1836 727" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1386 757, 1836 757" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1386 787, 1836 787" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1386 817, 1836 817" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1386 847, 1836 847" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1386 877, 1836 877" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1386 907, 1836 907" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polygon fill="#ffff80" points="1836 697, 1836 682, 2021 682, 2036 697, 2021 712, 1836 712, 1836 697" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1836" y="697">CS0</text>
<polygon fill="#ffff80" points="1836 727, 1836 712, 2021 712, 2036 727, 2021 742, 1836 742, 1836 727" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1836" y="727">CS1</text>
<polygon fill="#ffff80" points="1836 757, 1836 742, 2021 742, 2036 757, 2021 772, 1836 772, 1836 757" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1836" y="757">CS2</text>
<polygon fill="#ffff80" points="1836 787, 1836 772, 2021 772, 2036 787, 2021 802, 1836 802, 1836 787" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1836" y="787">CS3</text>
<polygon fill="#ffff80" points="1836 817, 1836 802, 2021 802, 2036 817, 2021 832, 1836 832, 1836 817" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1836" y="817">CS4</text>
<polygon fill="#ffff80" points="1836 847, 1836 832, 2021 832, 2036 847, 2021 862, 1836 862, 1836 847" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1836" y="847">CS5</text>
<polygon fill="#ffff80" points="1836 877, 1836 862, 2021 862, 2036 877, 2021 892, 1836 892, 1836 877" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1836" y="877">CS6</text>
<polygon fill="#ffff80" points="1836 907, 1836 892, 2021 892, 2036 907, 2021 922, 1836 922, 1836 907" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1836" y="907">CS7</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="宋体" font-size="22" font-weight="400" text-anchor="start" x="1436" y="697">(80H~87H)</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="宋体" font-size="22" font-weight="400" text-anchor="start" x="1436" y="727">(88H~8FH)</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="宋体" font-size="22" font-weight="400" text-anchor="start" x="1436" y="757">(90H~97H)</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="宋体" font-size="22" font-weight="400" text-anchor="start" x="1436" y="787">(98H~9FH)</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="宋体" font-size="22" font-weight="400" text-anchor="start" x="1436" y="817">(A0H~A7H)</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="宋体" font-size="22" font-weight="400" text-anchor="start" x="1436" y="847">(A8H~AFH)</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="宋体" font-size="22" font-weight="400" text-anchor="start" x="1436" y="877">(B0H~B7H)</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="宋体" font-size="22" font-weight="400" text-anchor="start" x="1436" y="907">(B8H~BFH)</text>
<polyline fill="none" points="636 367, 1836 367" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="636 517, 1836 517" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<circle cx="286" cy="487" fill="#0000ff" r="8" stroke="#0000ff" stroke-width="5"/>
</svg>
# 说明
IO接口芯片地址译码模块
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<project id="3407fe40-bd78-42b5-914a-e269ea66b67f" name="Lab007" version="1">
<files>
<filefolder id="d7502e9e-b220-4715-a645-2f139d9b4f34" name="MEM">
<file relativepath="MEM\MEM.dlsche"/>
<file relativepath="MEM\ram.asm"/>
<file relativepath="MEM\ram.bat"/>
<file relativepath="MEM\ram.rxm"/>
<file relativepath="MEM\README.md"/>
</filefolder>
<filefolder id="c6ec748e-8eff-4fcb-9ff0-d62ba30af439" name="IO">
<file relativepath="IO\IO.dlsche"/>
<file relativepath="IO\README.md"/>
</filefolder>
<filefolder id="05bbcd4e-c835-435e-a4d7-dae340588e14" name="8086">
<file relativepath="8086\8086.dlsche"/>
<file relativepath="8086\8086.pdf"/>
<file relativepath="8086\ALU.dlsche"/>
<file relativepath="8086\BRANCH.dlsche"/>
<file relativepath="8086\CU.dlsche"/>
<file relativepath="8086\FLAG.dlsche"/>
<file relativepath="8086\PC.dlsche"/>
<file relativepath="8086\README.md"/>
<file relativepath="8086\REGS.dlsche"/>
<file relativepath="8086\rom.bat"/>
<file relativepath="8086\rom.masm"/>
<file relativepath="8086\rom.rxm"/>
<file relativepath="8086\uPC_NEXT.dlsche"/>
</filefolder>
<filefolder id="84c9ca18-f243-47be-98eb-7bdfd63e543a" name="DAC0832">
<file relativepath="DAC0832\DAC.dlsche"/>
<file relativepath="DAC0832\DAC0832.dlsche"/>
<file relativepath="DAC0832\DAC0832.pdf"/>
<file relativepath="DAC0832\README.md"/>
</filefolder>
<file relativepath="DAC0832_test.dlsche"/>
<file relativepath="README.md"/>
<file relativepath="top.dlsche"/>
</files>
</project>
添加文件
<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<svg height="1454" version="1.1" width="1952" xmlns="http://www.w3.org/2000/svg">
<polygon fill="#ffff80" points="21 402, 21 377, 146 377, 171 402, 146 427, 21 427, 21 402" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="21" y="402">ABUS[7..0]</text>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="422" y2="472"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="442" y2="492"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="462" y2="512"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="482" y2="532"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="502" y2="552"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="522" y2="572"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="542" y2="592"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="562" y2="612"/>
<polyline fill="none" points="271 472, 541 472" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 492, 541 492" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 512, 541 512" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 532, 541 532" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 552, 541 552" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 572, 541 572" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 592, 541 592" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 612, 541 612" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="341" y="472">ABUS0</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="341" y="492">ABUS1</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="341" y="512">ABUS2</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="341" y="532">ABUS3</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="341" y="552">ABUS4</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="341" y="572">ABUS5</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="341" y="592">ABUS6</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="341" y="612">ABUS7</text>
<polygon fill="#ffff80" points="21 682, 21 657, 146 657, 171 682, 146 707, 21 707, 21 682" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="21" y="682">DBUS[7..0]</text>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="862" y2="812"/>
<polyline fill="none" points="541 812, 271 812" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="842" y2="792"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="822" y2="772"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="802" y2="752"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="782" y2="732"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="762" y2="712"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="742" y2="692"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="221" x2="271" y1="722" y2="672"/>
<polyline fill="none" points="271 792, 541 792" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 772, 541 772" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 752, 541 752" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 732, 541 732" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 712, 541 712" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 692, 541 692" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="271 672, 541 672" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="311" y="672">DBUS0</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="311" y="692">DBUS1</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="311" y="712">DBUS2</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="311" y="732">DBUS3</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="311" y="752">DBUS4</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="311" y="772">DBUS5</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="311" y="792">DBUS6</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="12" font-weight="400" text-anchor="start" x="311" y="812">DBUS7</text>
<polygon fill="#ffff80" points="21 1112, 21 1087, 146 1087, 171 1112, 146 1137, 21 1137, 21 1112" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="21" y="1112">WR_OUT</text>
<polygon fill="#ffff80" points="21 892, 21 867, 146 867, 171 892, 146 917, 21 917, 21 892" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="21" y="892">CLK</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="22" font-weight="400" text-anchor="start" x="1481" y="472">DBUS0</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="22" font-weight="400" text-anchor="start" x="1481" y="502">DBUS1</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="22" font-weight="400" text-anchor="start" x="1481" y="532">DBUS2</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="22" font-weight="400" text-anchor="start" x="1481" y="562">DBUS3</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="22" font-weight="400" text-anchor="start" x="1481" y="592">DBUS4</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="22" font-weight="400" text-anchor="start" x="1481" y="622">DBUS5</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="22" font-weight="400" text-anchor="start" x="1481" y="652">DBUS6</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="22" font-weight="400" text-anchor="start" x="1481" y="682">DBUS7</text>
<polyline fill="none" points="1431 472, 1631 472" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1431 502, 1631 502" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1431 532, 1631 532" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1431 562, 1631 562" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1431 592, 1631 592" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1431 622, 1631 622" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1431 652, 1631 652" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1431 682, 1631 682" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="1631" x2="1681" y1="472" y2="422"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="1631" x2="1681" y1="502" y2="452"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="1631" x2="1681" y1="532" y2="482"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="1631" x2="1681" y1="562" y2="512"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="1631" x2="1681" y1="592" y2="542"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="1631" x2="1681" y1="622" y2="572"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="1631" x2="1681" y1="652" y2="602"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="1631" x2="1681" y1="682" y2="632"/>
<polyline fill="none" points="791 472, 1181 472" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="791 492, 1081 492, 1081 502, 1181 502" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="791 512, 1061 512, 1061 532, 1181 532" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="791 532, 1041 532, 1041 562, 1181 562" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="791 552, 1011 552, 1011 592, 1181 592" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="791 572, 981 572, 981 622, 1181 622" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="791 592, 951 592, 951 652, 1181 652" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="791 612, 921 612, 921 682, 1181 682" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="150" font-weight="700" text-anchor="start" x="651" y="192">MEM模块</text>
<polygon fill="#ffff80" points="21 1172, 21 1147, 146 1147, 171 1172, 146 1197, 21 1197, 21 1172" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="21" y="1172">MIO</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="681" x2="621" y1="1112" y2="1112"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="681" x2="621" y1="1172" y2="1172"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="811" x2="871" y1="1142" y2="1142"/>
<path d="M677 1096 C 703 1135, 676 1185, 676 1185, 676 1185, 676 1185, 676 1185" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="677 1095, 735 1095" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="676 1185, 734 1185" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<path d="M735 1095 C 787 1095, 811 1142, 811 1142" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<path d="M733 1185 C 789 1185, 811 1142, 811 1142" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="726" y="1085">U1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="714" y="1236">OR</text>
<polygon fill="#ffff80" points="21 1372, 21 1347, 146 1347, 171 1372, 146 1397, 21 1397, 21 1372" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="21" y="1372">READ_OUT</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="681" x2="621" y1="1312" y2="1312"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="681" x2="621" y1="1372" y2="1372"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="811" x2="871" y1="1342" y2="1342"/>
<path d="M677 1296 C 703 1335, 676 1385, 676 1385, 676 1385, 676 1385, 676 1385" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="677 1295, 735 1295" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="676 1385, 734 1385" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<path d="M735 1295 C 787 1295, 811 1342, 811 1342" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<path d="M733 1385 C 789 1385, 811 1342, 811 1342" fill="none" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="726" y="1285">U2</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="714" y="1436">OR</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="宋体" font-size="25" font-weight="400" text-anchor="start" x="21" y="1312">MIO为高电平表示访问存储器</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="281" x2="221" y1="1172" y2="1172"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="361" x2="421" y1="1172" y2="1172"/>
<circle cx="357" cy="1172" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<polygon fill="#ffffff" fill-opacity="0.5" points="281 1122, 281 1222, 351 1172, 281 1122" stroke="#000000" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="301" y="1136">U3</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="281" y="1268">NOT</text>
<polyline fill="none" points="221 562, 221 402, 171 402" stroke="#000080" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<polyline fill="none" points="221 862, 221 682, 171 682" stroke="#000080" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<polyline fill="none" points="1681 632, 1681 412, 1781 412" stroke="#000080" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<polygon fill="#ffff80" points="1781 412, 1781 387, 1906 387, 1931 412, 1906 437, 1781 437, 1781 412" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1781" y="412">DBUS[7..0]</text>
<polyline fill="none" points="171 1372, 621 1372" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="221 1172, 171 1172" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="421 1172, 621 1172" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="621 1112, 171 1112" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="621 1312, 521 1312, 521 1172" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="541 892, 171 892" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="871 1142, 921 1142, 921 1012, 471 1012, 471 872, 541 872" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="871 1342, 1121 1342, 1121 742, 1181 742" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="472" y2="472"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="472">A0</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="492" y2="492"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="492">A1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="512" y2="512"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="512">A2</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="532" y2="532"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="532">A3</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="552" y2="552"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="552">A4</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="572" y2="572"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="572">A5</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="592" y2="592"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="592">A6</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="612" y2="612"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="612">A7</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="672" y2="672"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="672">D0</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="692" y2="692"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="692">D1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="712" y2="712"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="712">D2</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="732" y2="732"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="732">D3</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="752" y2="752"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="752">D4</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="772" y2="772"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="772">D5</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="792" y2="792"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="792">D6</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="812" y2="812"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="624" y="812">D7</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="741" x2="791" y1="472" y2="472"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="708" y="472">Q0</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="741" x2="791" y1="492" y2="492"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="708" y="492">Q1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="741" x2="791" y1="512" y2="512"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="708" y="512">Q2</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="741" x2="791" y1="532" y2="532"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="708" y="532">Q3</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="741" x2="791" y1="552" y2="552"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="708" y="552">Q4</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="741" x2="791" y1="572" y2="572"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="708" y="572">Q5</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="741" x2="791" y1="592" y2="592"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="708" y="592">Q6</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="741" x2="791" y1="612" y2="612"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="708" y="612">Q7</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="581" x2="541" y1="872" y2="872"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="657" y="872">^W\R</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="591" x2="541" y1="892" y2="892"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="644" y="892">CLK</text>
<rect fill="#ff8057" fill-opacity="0.5" height="490" stroke="#000000" stroke-width="5" width="150" x="591" y="442"/>
<polyline fill="none" points="591 882, 601 892, 591 902" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="1"/>
<circle cx="586" cy="872" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="90" font-weight="700" text-anchor="start" x="551" y="432">RAM</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="611" y="972">256RAM1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1231" x2="1181" y1="472" y2="472"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1264" y="472">A0</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1231" x2="1181" y1="502" y2="502"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1264" y="502">A1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1231" x2="1181" y1="532" y2="532"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1264" y="532">A2</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1231" x2="1181" y1="562" y2="562"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1264" y="562">A3</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1231" x2="1181" y1="592" y2="592"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1264" y="592">A4</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1231" x2="1181" y1="622" y2="622"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1264" y="622">A5</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1231" x2="1181" y1="652" y2="652"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1264" y="652">A6</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1231" x2="1181" y1="682" y2="682"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1264" y="682">A7</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1381" x2="1431" y1="472" y2="472"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1348" y="472">D0</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1381" x2="1431" y1="502" y2="502"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1348" y="502">D1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1381" x2="1431" y1="532" y2="532"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1348" y="532">D2</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1381" x2="1431" y1="562" y2="562"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1348" y="562">D3</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1381" x2="1431" y1="592" y2="592"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1348" y="592">D4</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1381" x2="1431" y1="622" y2="622"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1348" y="622">D5</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1381" x2="1431" y1="652" y2="652"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1348" y="652">D6</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1381" x2="1431" y1="682" y2="682"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="1348" y="682">D7</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1221" x2="1181" y1="742" y2="742"/>
<text alignment-baseline="central" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="1275" y="741">^EN</text>
<rect fill="#a0c0ff" fill-opacity="0.5" height="350" stroke="#000000" stroke-width="5" width="150" x="1231" y="432"/>
<circle cx="1226" cy="742" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1231" y="422">MEM_gate</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1231" y="832">BUS_TRANS8</text>
<circle cx="521" cy="1172" fill="#0000ff" r="8" stroke="#0000ff" stroke-width="5"/>
</svg>
# 说明
8086 微机系统的MEM主存储器,存储指令和数据
\ No newline at end of file
/*******************************************************************************
*******************************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
typedef unsigned char BYTE;
typedef long BOOL;
#define FALSE 0
#define TRUE 1
#define MAX_LINE_LENGTH 256 // 一行代码最多可以有多少个字符
#define MAX_LINE_COUNT 1024 // 源代码文件最多可以有多少行
#define MAX_MACHINE_CODE_BYTE_COUNT 256 // 源代码编译后最多可以有多少个字节机器码
#define MAX_SYMBOL_LENGTH 64 // 一个符号最多可以包含多少个字符
#define MAX_SYMBOL_COUNT 256 // 源代码文件中最多可以包含多少个符号
#ifndef MAX_PATH
#define MAX_PATH 256 // 文件路径最多可以包含多少个字符
#endif
// 代码行数据库。记录源代码文件中所有代码行的信息(包括注释行、空行)
struct LINE_RECORD
{
char line_string[MAX_LINE_LENGTH]; // 代码行的内容
unsigned long line_num; // 行号
unsigned long address; // 此行代码转换的机器码在映像文件中的地址(偏移)
int machine_code_count; // 此行代码转换的机器码的字节数量
unsigned long flag; // 代码行标志位,32位
};
struct LINE_RECORD line_database[MAX_LINE_COUNT] = { 0 };
int line_count = 0;
int machine_code_line_count = 0; // 记录产生了机器码的代码行的数量
// 在此定义所有的代码行标志位。注意,代码行标志位是按位或的关系。
#define LF_INSTRUCTION 0x00000001 // 代码行标志位的最低位是1,表示此行是一条指令,否则表示此行是数据
// 重定位表。如果指令中使用了标号、变量名等符号,在第一次扫描时无法确定他们的地址,需要
// 在第二次扫描时进行重定位。
struct REALLOCATE
{
unsigned long address; // 第一次扫描时,在这里记录了需要重定位的机器码的地址(偏移),
// 第二次扫描时,根据符号的地址进行重定位。
char symbol_name[MAX_SYMBOL_LENGTH]; // 需要重定位的符号名称。
int line_num; // 行号。
};
struct REALLOCATE reallocate_table[MAX_LINE_COUNT] = { 0 };
int reallocate_count = 0;
// 符号表。符号包括源代码中的标号、变量名。
struct SYMBOL
{
char name[MAX_SYMBOL_LENGTH]; // 符号名称
unsigned long address; // 符号表示的地址。重定位时需要用到。
int machine_code_count; // 符号生成的机器码的数量(以字节为单位)。
int line_num; // 行号
int ref_count; // 引用计数
};
struct SYMBOL symbol_table[MAX_SYMBOL_COUNT] = { 0 };
int symbol_count = 0;
// 汇编过程的状态
enum
{
AS_BEGIN // 起始状态。在遇到代码段名称前,处于此状态
, AS_INT_TABLE // 正在处理中断向量列表。遇到向量列表名称后,遇到代码段名称前,处于此状态
, AS_TEXT // 正在处理代码段。遇到代码段名称后,遇到数据的名称前,处于此状态
, AS_DATA // 正在处理数据段。遇到数据段名称后,处于此状态
};
unsigned long assembler_state = AS_BEGIN;
//
// 在下面定义所有的关键字
//
// 段名称
const char* int_table_section_keyword = ".int_table"; // 中断向量列表标志
const char* code_section_keyword = ".text"; // 代码段标志
char const* data_section_keyword = ".data"; // 数据段标志
// 指令名称
const char* mov_instruction_keyword = "mov";
const char* add_instruction_keyword = "add";
const char* adc_instruction_keyword = "adc";
const char* sub_instruction_keyword = "sub";
const char* sbb_instruction_keyword = "sbb";
const char* and_instruction_keyword = "and";
const char* or_instruction_keyword = "or";
const char* xor_instruction_keyword = "xor";
const char* shr_instruction_keyword = "shr";
const char* shl_instruction_keyword = "shl";
const char* rcr_instruction_keyword = "rcr";
const char* rcl_instruction_keyword = "rcl";
const char* sal_instruction_keyword = "sal";
const char* sar_instruction_keyword = "sar";
const char* rol_instruction_keyword = "rol";
const char* ror_instruction_keyword = "ror";
const char* not_instruction_keyword = "not";
const char* push_instruction_keyword = "push";
const char* pop_instruction_keyword = "pop";
const char* in_instruction_keyword = "in";
const char* out_instruction_keyword = "out";
const char* call_instruction_keyword = "call";
const char* ret_instruction_keyword = "ret";
const char* int_instruction_keyword = "int";
const char* iret_instruction_keyword = "iret";
const char* inc_instruction_keyword = "inc";
const char* dec_instruction_keyword = "dec";
const char* lea_instruction_keyword = "lea";
const char* cmp_instruction_keyword = "cmp";
const char* nop_instruction_keyword = "nop";
const char* cli_instruction_keyword = "cli";
const char* sti_instruction_keyword = "sti";
const char* jmp_instruction_keyword = "jmp";
const char* jc_instruction_keyword = "jc";
const char* jz_instruction_keyword = "jz";
const char* je_instruction_keyword = "je";
const char* jne_instruction_keyword = "jne";
const char* jnz_instruction_keyword = "jnz";
// 通用寄存器名称
const char* al_register_keyword = "al";
const char* bl_register_keyword = "bl";
const char* cl_register_keyword = "cl";
const char* dl_register_keyword = "dl";
const char* sp_register_keyword = "sp";
const char* bp_register_keyword = "bp";
const char* si_register_keyword = "si";
const char* di_register_keyword = "di";
const char* cs_register_keyword = "cs";
const char* ds_register_keyword = "ds";
const char* ss_register_keyword = "ss";
const char* es_register_keyword = "es";
const char* al_register_indirect_keyword = "[al]";
const char* bl_register_indirect_keyword = "[bl]";
const char* cl_register_indirect_keyword = "[cl]";
const char* dl_register_indirect_keyword = "[dl]";
const char* sp_register_indirect_keyword = "[sp]";
const char* bp_register_indirect_keyword = "[bp]";
const char* si_register_indirect_keyword = "[si]";
const char* di_register_indirect_keyword = "[di]";
const char* cs_register_indirect_keyword = "[cs]";
const char* ds_register_indirect_keyword = "[ds]";
const char* ss_register_indirect_keyword = "[ss]";
const char* es_register_indirect_keyword = "[es]";
const char* delimit_char = "\n\t\r "; // 需要忽略的空白字符
const char* delimit_char_comma = "\n\t\r, "; // 需要忽略的空白字符,包括英文逗号
// 汇编产生的机器码
#define MAX_MACHINE_CODE 1024
BYTE machine_code[MAX_MACHINE_CODE];
unsigned long machine_code_address = 0;
unsigned long machine_code_old_address = 0;
const char* assembly_file_name = NULL; // 汇编文件路径
const char* target_file_name = NULL; // 目标文件路径
const char* list_file_name = NULL; // 列表文件路径
const char* dbg_file_name = NULL; // 调试信息文件路径
const unsigned long dbg_file_magic = 58;
const unsigned long dbg_file_version = 1;
// 输出汇编过程中发现的语法错误信息
void error_msg(const char* error_msg, int line_num)
{
if (line_num >= 1)
{
printf("%s:%d: error: %s\n", assembly_file_name, line_num, error_msg);
}
else
{
printf("%s: error: %s\n", assembly_file_name, error_msg);
}
exit(1);
}
char formated_msg[1024]; // 将格式化后的错误信息放在此字符串中。
void error_msg_miss_op(const char* instruction_name, int line_num)
{
sprintf(formated_msg, "%s 指令缺少操作数。", instruction_name);
error_msg(formated_msg, line_num);
}
void error_msg_wrong_op(const char* instruction_name, int line_num)
{
sprintf(formated_msg, "%s 指令不支持这样的操作数。", instruction_name);
error_msg(formated_msg, line_num);
}
void error_msg_same_symbol(const char* symbol, int line_num, int ref_line_num)
{
sprintf(formated_msg, "符号 %s 重复定义。参见第 %d 行。", symbol, ref_line_num);
error_msg(formated_msg, line_num);
}
void error_msg_keyword_symbol(const char* symbol, int line_num)
{
sprintf(formated_msg, "不能使用保留的关键字 %s 作为符号名称。", symbol);
error_msg(formated_msg, line_num);
}
void error_msg_keyword_int_vector(const char* vector, int line_num)
{
sprintf(formated_msg, "不能使用保留的关键字 %s 作为中断向量名称。", vector);
error_msg(formated_msg, line_num);
}
void error_msg_wrong_data(const char* data, int line_num)
{
sprintf(formated_msg, "%s 不是有效的数据。", data);
error_msg(formated_msg, line_num);
}
// 输出汇编过程中发现的警告信息
void warning_msg(const char* warning_msg, int line_num)
{
if (line_num >= 1)
{
printf("%s:%d: warning: %s\n", assembly_file_name, line_num, warning_msg);
}
else
{
printf("%s: warning: %s\n", assembly_file_name, warning_msg);
}
}
void warning_msg_invalid_line(int line_num)
{
warning_msg("忽略无效的代码行。", line_num);
}
void warning_msg_unref_symbol(const char* symbol, int line_num)
{
sprintf(formated_msg, "符号 %s 未被引用。", symbol);
warning_msg(formated_msg, line_num);
}
// 判断是否是立即数。如果是数字开头,或者是负号开头的,就认为是立即数。
int is_immediate(const char* token)
{
return (isdigit(token[0]) || '-' == token[0]) ? 1 : 0;
}
// 判断是否是立即数地址。类如,[4]
int is_immediate_address(const char* token)
{
// 最后一个字符必须是"]"
if (token[strlen(token) - 1] != ']')
{
return 0;
}
// 第一个字符必须是"["
if (token[0] != '[')
{
return 0;
}
// 后面的字符必须是数字开头
return (isdigit(token[1]) || ' ' == token[1]) ? 1 : 0;
}
// 判断是否是主存数据
int is_main_memory(const char* token)
{
return (isdigit(token[0]) || '@' == token[0]) ? 1 : 0;
}
// 指令操作数类型
enum
{
OT_REGISTER_AL // al
, OT_REGISTER_BL // bl
, OT_REGISTER_CL // cl
, OT_REGISTER_DL // dl
, OT_REGISTER_SP // sp
, OT_REGISTER_BP // bp
, OT_REGISTER_SI // si
, OT_REGISTER_DI // di
, OT_REGISTER_CS // cs
, OT_REGISTER_DS // ds
, OT_REGISTER_SS // ss
, OT_REGISTER_ES // es
, OT_REGISTER_AL_INDIRECT // [al]
, OT_REGISTER_BL_INDIRECT // [bl]
, OT_REGISTER_CL_INDIRECT // [cl]
, OT_REGISTER_DL_INDIRECT // [dl]
, OT_REGISTER_SP_INDIRECT // [sp]
, OT_REGISTER_BP_INDIRECT // [bp]
, OT_REGISTER_SI_INDIRECT // [si]
, OT_REGISTER_DI_INDIRECT // [di]
, OT_REGISTER_CS_INDIRECT // [cs]
, OT_REGISTER_DS_INDIRECT // [ds]
, OT_REGISTER_SS_INDIRECT // [ss]
, OT_REGISTER_ES_INDIRECT // [es]
, OT_IMMEDIATE // 立即数
, OT_SYMBOL // 符号
};
// 得到指令操作数的类型
unsigned long get_operand_type(const char* op)
{
unsigned long op_type;
if (stricmp(op, al_register_keyword) == 0)
{
op_type = OT_REGISTER_AL;
}
else if (stricmp(op, bl_register_keyword) == 0)
{
op_type = OT_REGISTER_BL;
}
else if (stricmp(op, cl_register_keyword) == 0)
{
op_type = OT_REGISTER_CL;
}
else if (stricmp(op, dl_register_keyword) == 0)
{
op_type = OT_REGISTER_DL;
}
else if (stricmp(op, sp_register_keyword) == 0)
{
op_type = OT_REGISTER_SP;
}
else if (stricmp(op, bp_register_keyword) == 0)
{
op_type = OT_REGISTER_BP;
}
else if (stricmp(op, si_register_keyword) == 0)
{
op_type = OT_REGISTER_SI;
}
else if (stricmp(op, di_register_keyword) == 0)
{
op_type = OT_REGISTER_DI;
}
else if (stricmp(op, cs_register_keyword) == 0)
{
op_type = OT_REGISTER_CS;
}
else if (stricmp(op, ds_register_keyword) == 0)
{
op_type = OT_REGISTER_DS;
}
else if (stricmp(op, ss_register_keyword) == 0)
{
op_type = OT_REGISTER_SS;
}
else if (stricmp(op, es_register_keyword) == 0)
{
op_type = OT_REGISTER_ES;
}
else if (stricmp(op, al_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_AL_INDIRECT;
}
else if (stricmp(op, bl_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_BL_INDIRECT;
}
else if (stricmp(op, cl_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_CL_INDIRECT;
}
else if (stricmp(op, dl_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_DL_INDIRECT;
}
else if (stricmp(op, sp_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_SP_INDIRECT;
}
else if (stricmp(op, bp_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_BP_INDIRECT;
}
else if (stricmp(op, si_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_SI_INDIRECT;
}
else if (stricmp(op, di_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_DI_INDIRECT;
}
else if (stricmp(op, cs_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_CS_INDIRECT;
}
else if (stricmp(op, ds_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_DS_INDIRECT;
}
else if (stricmp(op, ss_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_SS_INDIRECT;
}
else if (stricmp(op, es_register_indirect_keyword) == 0)
{
op_type = OT_REGISTER_ES_INDIRECT;
}
else if (is_immediate(op))
{
op_type = OT_IMMEDIATE;
}
else
{
op_type = OT_SYMBOL;
}
return op_type;
}
// 根据寄存器,得到一个机器码
char get_machine_code_from_r(unsigned long op_type)
{
return (char)(op_type - OT_REGISTER_AL);
}
// 根据通用寄存器和机器码的基础值,得到一个机器码
char get_machine_code_from_r_indirect(unsigned long op_type)
{
return (char)(op_type - OT_REGISTER_AL_INDIRECT);
}
// 根据立即数得到一个机器码。注意,允许使用负数,所以返回值是带符号的 8 位 char。
char get_machine_code_from_immediate(const char* immediate)
{
char* end;
int start_index = (immediate[0] == '-' ? 1 : 0);
int base = (immediate[start_index] == '0' && (immediate[start_index + 1] == 'x' || immediate[start_index + 1] == 'X')) ? 16 : 10;
return (char)strtol(immediate, &end, base);
}
// 根据立即数地址得到一个机器码。首先去除中括号,再将立即数转换为带符号的8位字符。
char get_machine_code_from_immediate_address(const char* immediate)
{
char d[7];
int i = 0;
int t = strlen(immediate);
for (; i < t - 2; i++)
{
d[i] = immediate[i + 1];
}
char* temp;
int base = (immediate[1] == '0' && (immediate[2] == 'x' || immediate[2] == 'X')) ? 16 : 10;
return (char)strtol(d, &temp, base);
}
// 向重定位表中添加一个重定位信息
void add_reallocate(const char* symbol, int line_num)
{
reallocate_table[reallocate_count].address = machine_code_address;
strcpy(reallocate_table[reallocate_count].symbol_name, symbol);
reallocate_table[reallocate_count].line_num = line_num;
reallocate_count++;
}
//////////////////////////////////////////////////////////////////////////////////////
// 汇编指令编译函数
// mov op1, op2
//
void parse_mov(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(mov_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_ES)
&& OT_IMMEDIATE == op2_type)
{
// mov reg, immediate
// 操作码
machine_code[machine_code_address] = 0x01;
machine_code_address++;
// reg为目的寄存器操作数
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 立即数机器码
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_ES)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_ES))
{
// mov reg, reg
// 操作码
machine_code[machine_code_address] = 0x02;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_ES) && OT_SYMBOL == op2_type)
{
// mov reg, symbol
// 操作码
machine_code[machine_code_address] = 0x03;
machine_code_address++;
// 目的操作数机器码
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 重定位
add_reallocate(op2, line_num);
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_ES)
&& (op2_type >= OT_REGISTER_AL_INDIRECT && op2_type <= OT_REGISTER_ES_INDIRECT))
{
// mov reg, [reg]
// 操作码
machine_code[machine_code_address] = 0x04;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r_indirect(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL_INDIRECT && op1_type <= OT_REGISTER_ES_INDIRECT)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_ES))
{
// mov [reg], reg
// 操作码
machine_code[machine_code_address] = 0x05;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r_indirect(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL_INDIRECT && op1_type <= OT_REGISTER_ES_INDIRECT) && OT_IMMEDIATE == op2_type)
{
// mov [reg], immediate
// 操作码
machine_code[machine_code_address] = 0x06;
machine_code_address++;
// 目的操作数
machine_code[machine_code_address] = get_machine_code_from_r_indirect(op1_type);
machine_code_address++;
// 立即数机器码
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else if (OT_SYMBOL == op1_type && (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_ES))
{
// mov symbol, reg
machine_code[machine_code_address] = 0x07;
machine_code_address++;
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
machine_code[machine_code_address] = rs;
machine_code_address++;
// 重定位
add_reallocate(op1, line_num);
machine_code_address++;
}
else
{
error_msg_wrong_op(mov_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////////////////////////
// 加法指令
// add op1, op2
void parse_add(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(add_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// add reg, reg
// 操作码
machine_code[machine_code_address] = 0x08;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL_INDIRECT && op2_type <= OT_REGISTER_DI_INDIRECT))
{
// add reg, [reg]
// 操作码
machine_code[machine_code_address] = 0x0a;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r_indirect(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_SYMBOL == op2_type)
{
// add reg, symbol
// 操作码
machine_code[machine_code_address] = 0x0c;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 重定位
add_reallocate(op2, line_num);
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_IMMEDIATE == op2_type)
{
// add reg, immediate
machine_code[machine_code_address] = 0x0e;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 立即数
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else
{
error_msg_wrong_op(add_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
///////////////////////////////////////////////////////////////////////////////////////////////////////
// 带进位的加法指令
// adc op1, op2
void parse_adc(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(adc_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// adc reg, reg
// 操作码
machine_code[machine_code_address] = 0x10;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL_INDIRECT && op2_type <= OT_REGISTER_DI_INDIRECT))
{
// adc reg, [reg]
// 操作码
machine_code[machine_code_address] = 0x12;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r_indirect(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_SYMBOL == op2_type)
{
// adc reg, symbol
// 操作码
machine_code[machine_code_address] = 0x14;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 重定位
add_reallocate(op2, line_num);
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_IMMEDIATE == op2_type)
{
// adc reg, immediate
machine_code[machine_code_address] = 0x16;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 立即数
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else
{
error_msg_wrong_op(adc_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
////////////////////////////////////////////////////////////////////////////////////////////
// 减法指令
// sub op1, op2
void parse_sub(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(sub_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// sub reg, reg
// 操作码
machine_code[machine_code_address] = 0x18;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL_INDIRECT && op2_type <= OT_REGISTER_DI_INDIRECT))
{
// sub reg, [reg]
// 操作码
machine_code[machine_code_address] = 0x1a;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r_indirect(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_SYMBOL == op2_type)
{
// sub reg, symbol
// 操作码
machine_code[machine_code_address] = 0x1c;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 重定位
add_reallocate(op2, line_num);
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_IMMEDIATE == op2_type)
{
// sub reg, immediate
machine_code[machine_code_address] = 0x1e;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 立即数
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else
{
error_msg_wrong_op(sub_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
///////////////////////////////////////////////////////////////////////////////////////////////////////////////
// 借位减法指令
// sbb op1, op2
void parse_sbb(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(sbb_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// sbb reg, reg
// 操作码
machine_code[machine_code_address] = 0x20;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL_INDIRECT && op2_type <= OT_REGISTER_DI_INDIRECT))
{
// sbb reg, [reg]
// 操作码
machine_code[machine_code_address] = 0x22;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r_indirect(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_SYMBOL == op2_type)
{
// sbb reg, symbol
// 操作码
machine_code[machine_code_address] = 0x24;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 重定位
add_reallocate(op2, line_num);
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_IMMEDIATE == op2_type)
{
// sbb reg, immediate
machine_code[machine_code_address] = 0x26;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 立即数
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else
{
error_msg_wrong_op(sbb_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
/////////////////////////////////////////////////////////////////////////////////////////
// 增减1指令
// inc reg
void parse_inc(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char);
if (NULL == op)
{
error_msg_miss_op(inc_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
if (op_type >= OT_REGISTER_AL && op_type <= OT_REGISTER_DI)
{
//
machine_code[machine_code_address] = 0x78;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op_type);
machine_code_address++;
}
else
{
error_msg_wrong_op(inc_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// dec reg
void parse_dec(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char);
if (NULL == op)
{
error_msg_miss_op(dec_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
if (op_type >= OT_REGISTER_AL && op_type <= OT_REGISTER_DI)
{
//
machine_code[machine_code_address] = 0x79;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op_type);
machine_code_address++;
}
else
{
error_msg_wrong_op(dec_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////////////////////////////////////////////
// 按位与指令
// and op1, op2
void parse_and(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(and_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// and reg, reg
// 操作码
machine_code[machine_code_address] = 0x2a;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL_INDIRECT && op2_type <= OT_REGISTER_DI_INDIRECT))
{
// and reg, [reg]
// 操作码
machine_code[machine_code_address] = 0x2c;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r_indirect(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_SYMBOL == op2_type)
{
// and reg, symbol
// 操作码
machine_code[machine_code_address] = 0x2e;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 重定位
add_reallocate(op2, line_num);
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_IMMEDIATE == op2_type)
{
// and reg, immediate
machine_code[machine_code_address] = 0x30;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 立即数
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else
{
error_msg_wrong_op(and_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
/////////////////////////////////////////////////////////////////////////////////////
// 按位或指令
// or op1, op2
void parse_or(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(or_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// or reg, reg
// 操作码
machine_code[machine_code_address] = 0x32;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL_INDIRECT && op2_type <= OT_REGISTER_DI_INDIRECT))
{
// or reg, [reg]
// 操作码
machine_code[machine_code_address] = 0x34;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r_indirect(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_SYMBOL == op2_type)
{
// or reg, symbol
// 操作码
machine_code[machine_code_address] = 0x36;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 重定位
add_reallocate(op2, line_num);
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_IMMEDIATE == op2_type)
{
// or reg, immediate
machine_code[machine_code_address] = 0x38;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 立即数
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else
{
error_msg_wrong_op(or_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
/////////////////////////////////////////////////////////////////////////////////////
// 按位异或指令
// xor op1, op2
void parse_xor(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(xor_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// xor reg, reg
// 操作码
machine_code[machine_code_address] = 0x3a;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL_INDIRECT && op2_type <= OT_REGISTER_DI_INDIRECT))
{
// xor reg, [reg]
// 操作码
machine_code[machine_code_address] = 0x3c;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r_indirect(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_SYMBOL == op2_type)
{
// xor reg, symbol
// 操作码
machine_code[machine_code_address] = 0x3e;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 重定位
add_reallocate(op2, line_num);
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_IMMEDIATE == op2_type)
{
// xor reg, immediate
machine_code[machine_code_address] = 0x40;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 立即数
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else
{
error_msg_wrong_op(xor_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
////////////////////////////////////////////////////
//
// push reg
void parse_push(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char_comma);
if (NULL == op)
{
error_msg_miss_op(push_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
if (op_type >= OT_REGISTER_AL && op_type <= OT_REGISTER_ES)
{
machine_code[machine_code_address] = 0x42;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op_type);
machine_code_address++;
}
else
{
error_msg_wrong_op(push_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
/////////////////////////////////////////////////////////////////
//
// pop reg
void parse_pop(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char_comma);
if (NULL == op)
{
error_msg_miss_op(pop_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
if (op_type >= OT_REGISTER_AL && op_type <= OT_REGISTER_ES)
{
machine_code[machine_code_address] = 0x43;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op_type);
machine_code_address++;
}
else
{
error_msg_wrong_op(pop_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////////////////////////
//
// not reg
void parse_not(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char);
if (NULL == op)
{
error_msg_miss_op(not_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
// 目标操作数只能是通用寄存器
if (op_type >= OT_REGISTER_AL && op_type <= OT_REGISTER_DI)
{
machine_code[machine_code_address] = 0x44;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op_type);
machine_code_address++;
}
else
{
error_msg_wrong_op(not_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////////////////////
//
// cmp op1, op2
void parse_cmp(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(cmp_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_IMMEDIATE == op2_type)
{
// cmp reg, immediate
machine_code[machine_code_address] = 0x47;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 立即数
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// cmp reg, reg
// 操作码
machine_code[machine_code_address] = 0x49;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else
{
error_msg_wrong_op(xor_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////////////
//
// 接口访问指令
// in op1, op2
void parse_in(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(in_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if (OT_REGISTER_AL == op1_type && OT_IMMEDIATE == op2_type)
{
// in al, imm
machine_code[machine_code_address] = 0x4b;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
machine_code[machine_code_address] = get_machine_code_from_immediate(op2);
machine_code_address++;
}
else if (OT_REGISTER_AL == op1_type && OT_REGISTER_DL == op2_type)
{
// in al, dl
machine_code[machine_code_address] = 0x4c;
machine_code_address++;
//
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
rd = get_machine_code_from_r(op1_type);
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else
{
error_msg_wrong_op(in_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// out op1, op2
void parse_out(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(out_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if (OT_REGISTER_DL == op1_type && OT_REGISTER_AL == op2_type)
{
// out dl, al
machine_code[machine_code_address] = 0x4d;
machine_code_address++;
//
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
rd = get_machine_code_from_r(op1_type);
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else if (OT_IMMEDIATE == op1_type && OT_REGISTER_AL == op2_type)
{
// out imm, al
machine_code[machine_code_address] = 0x4e;
machine_code_address++;
//
machine_code[machine_code_address] = get_machine_code_from_r(op2_type);
machine_code_address++;
machine_code[machine_code_address] = get_machine_code_from_immediate(op1);
machine_code_address++;
}
else
{
error_msg_wrong_op(out_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
///////////////////////////////////////////////////////
//
// lea reg, symbol
void parse_lea(int line_num)
{
char *op1, *op2;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(lea_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI) && OT_SYMBOL == op2_type)
{
// lea reg, symbol
machine_code[machine_code_address] = 0x4f;
machine_code_address++;
machine_code[machine_code_address] = get_machine_code_from_r(op1_type);
machine_code_address++;
// 重定位
add_reallocate(op2, line_num);
machine_code_address++;
}
else
{
error_msg_wrong_op(lea_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////
//
// jz/je symbol
void parse_jz(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char);
if (NULL == op)
{
error_msg_miss_op(jz_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
if (OT_SYMBOL == op_type)
{
// jz symbol
machine_code[machine_code_address] = 0x54;
machine_code_address++;
// 重定位
add_reallocate(op, line_num);
machine_code_address++;
}
else
{
error_msg_wrong_op(jz_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////
//
// jnz/jne symbol
void parse_jnz(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char);
if (NULL == op)
{
error_msg_miss_op(jnz_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
if (OT_SYMBOL == op_type)
{
machine_code[machine_code_address] = 0x55;
machine_code_address++;
// 重定位
add_reallocate(op, line_num);
machine_code_address++;
}
else
{
error_msg_wrong_op(jnz_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////
//
// jc symbol
void parse_jc(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char);
if (NULL == op)
{
error_msg_miss_op(jc_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
if (OT_SYMBOL == op_type)
{
machine_code[machine_code_address] = 0x56;
machine_code_address++;
// 重定位
add_reallocate(op, line_num);
machine_code_address++;
}
else
{
error_msg_wrong_op(jc_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////////
// jmp symbol
void parse_jmp(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char);
if (NULL == op)
{
error_msg_miss_op(jmp_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
if (OT_SYMBOL == op_type)
{
// jmp symbol
machine_code[machine_code_address] = 0x57;
machine_code_address++;
// 重定位
add_reallocate(op, line_num);
machine_code_address++;
}
else
{
error_msg_wrong_op(jmp_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
////////////////////////////////////////////////////////////////////////////////////
//
// int immediate
void parse_int(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char);
if (NULL == op)
{
error_msg_miss_op(int_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
if (OT_IMMEDIATE == op_type)
{
// int immediate
machine_code[machine_code_address] = 0x5a;
machine_code_address++;
//
machine_code[machine_code_address] = 0xB4;
machine_code_address++;
machine_code[machine_code_address] = get_machine_code_from_immediate(op);
machine_code_address++;
}
else
{
error_msg_wrong_op(int_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// iret
void parse_iret(int line_num)
{
machine_code[machine_code_address] = 0x5d;
machine_code_address++;
//
machine_code[machine_code_address] = 0x44;
machine_code_address++;
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
/////////////////////////////////////////////////////////////////
//
// 移位指令
// sal op1, op2
void parse_sal(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(sal_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// 操作码
machine_code[machine_code_address] = 0x5f;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else
{
error_msg_wrong_op(sal_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// sar op1, op2
void parse_sar(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(sar_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// 操作码
machine_code[machine_code_address] = 0x61;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else
{
error_msg_wrong_op(sar_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// shl op1, op2
void parse_shl(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(shl_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// 操作码
machine_code[machine_code_address] = 0x63;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else
{
error_msg_wrong_op(shl_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// shr op1, op2
void parse_shr(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(shr_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// 操作码
machine_code[machine_code_address] = 0x65;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else
{
error_msg_wrong_op(shr_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// rol op1, op2
void parse_rol(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(rol_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// 操作码
machine_code[machine_code_address] = 0x67;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else
{
error_msg_wrong_op(rol_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// ror op1, op2
void parse_ror(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(ror_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// 操作码
machine_code[machine_code_address] = 0x69;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else
{
error_msg_wrong_op(ror_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// rcl op1, op2
void parse_rcl(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(rcl_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// 操作码
machine_code[machine_code_address] = 0x6b;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else
{
error_msg_wrong_op(rcl_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// rcr op1, op2
void parse_rcr(int line_num)
{
char *op1, *op2;
char rs, rd;
unsigned long op1_type, op2_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op1 = strtok(NULL, delimit_char_comma);
op2 = strtok(NULL, delimit_char);
if (NULL == op1 || NULL == op2)
{
error_msg_miss_op(rcr_instruction_keyword, line_num);
}
op1_type = get_operand_type(op1);
op2_type = get_operand_type(op2);
if ((op1_type >= OT_REGISTER_AL && op1_type <= OT_REGISTER_DI)
&& (op2_type >= OT_REGISTER_AL && op2_type <= OT_REGISTER_DI))
{
// 操作码
machine_code[machine_code_address] = 0x6d;
machine_code_address++;
// 源操作数寄存器rs
rs = get_machine_code_from_r(op2_type);
rs = rs << 4;
// 目的操作数
rd = get_machine_code_from_r(op1_type);
// 操作数机器码
machine_code[machine_code_address] = rs | rd;
machine_code_address++;
}
else
{
error_msg_wrong_op(rcr_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////////////////////////
//
// nop
void parse_nop(int line_num)
{
machine_code[machine_code_address] = 0x6f;
machine_code_address++;
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
//////////////////////////////////////////////////////////////////////////
//
// call symbol
void parse_call(int line_num)
{
char *op;
unsigned long op_type;
if (assembler_state != AS_TEXT)
{
warning_msg_invalid_line(line_num);
return;
}
op = strtok(NULL, delimit_char);
if (NULL == op)
{
error_msg_miss_op(call_instruction_keyword, line_num);
}
op_type = get_operand_type(op);
if (OT_SYMBOL == op_type)
{
// call symbol
machine_code[machine_code_address] = 0x71;
machine_code_address++;
// 重定位
add_reallocate(op, line_num);
machine_code_address++;
}
else
{
error_msg_wrong_op(call_instruction_keyword, line_num);
}
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
/////////////////////////////////////////////////////////////////////////////
//
// ret
void parse_ret(int line_num)
{
machine_code[machine_code_address] = 0x73;
machine_code_address++;
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
/////////////////////////////////////////////////////////////////////////////
//
// cli
void parse_cli(int line_num)
{
machine_code[machine_code_address] = 0x74;
machine_code_address++;
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
/////////////////////////////////////////////////////////////////////////////
//
// sti
void parse_sti(int line_num)
{
machine_code[machine_code_address] = 0x75;
machine_code_address++;
//
// 在代码行数据库中,标记此行是一个指令行
//
line_database[line_count].flag |= LF_INSTRUCTION;
}
// 向符号表中添加一个符号
void add_symbol(const char* symbol, int line_num)
{
int i;
// 符号名称不能重复
for (i = 0; i < symbol_count; i++)
{
if (stricmp(symbol, symbol_table[i].name) == 0)
{
error_msg_same_symbol(symbol, line_num, symbol_table[i].line_num);
}
}
// 符号数量有限
if (symbol_count == MAX_SYMBOL_COUNT)
{
sprintf(formated_msg, "定义了太多的符号。最多可以定义 %d 个符号。", MAX_SYMBOL_COUNT);
error_msg(formated_msg, line_num);
}
// 添加符号
strcpy(symbol_table[symbol_count].name, symbol);
symbol_table[symbol_count].address = machine_code_address;
symbol_table[symbol_count].line_num = line_num;
symbol_count++;
}
// 解析符号
void parse_symbol(const char* symbol_with_colon, int line_num)
{
char symbol[MAX_SYMBOL_LENGTH];
char* token;
// 删除符号末尾的冒号
strcpy(symbol, symbol_with_colon);
symbol[strlen(symbol) - 1] = 0;
if (AS_TEXT == assembler_state)
{
// 代码段中的标号作为符号。记录到符号表中,不产生机器码。
add_symbol(symbol, line_num);
// 标号必须单独占一行,否则报错
if (strtok(NULL, delimit_char) != NULL)
{
error_msg("标号必须单独占用一行。", line_num);
}
}
else if (AS_DATA == assembler_state)
{
// 数据段中的变量作为符号。一个变量可以包含多个字节数据。记录到符号表中,产生机器码。
add_symbol(symbol, line_num);
while ((token = strtok(NULL, delimit_char)) != NULL)
{
if (!is_immediate(token))
{
error_msg_wrong_data(token, line_num);
}
machine_code[machine_code_address] = get_machine_code_from_immediate(token);
machine_code_address++;
symbol_table[symbol_count - 1].machine_code_count++;
}
}
else
{
warning_msg_invalid_line(line_num);
}
}
// 解析中断向量
void parse_int_vector(const char* symbol_with_colon, int line_num)
{
char symbol[MAX_SYMBOL_LENGTH];
char* token;
if (AS_INT_TABLE == assembler_state)
{
// 重定位
add_reallocate(symbol_with_colon, line_num);
machine_code_address++;
// 中断向量必须单独占一行,否则报错
if (strtok(NULL, delimit_char) != NULL)
{
error_msg("中断向量必须单独占用一行。", line_num);
}
}
}
// 解析中断向量表开始标志
void parse_int_table_section_keyword(int line_num)
{
// 中断向量表标志
if (AS_TEXT == assembler_state)
{
error_msg("中断向量表不能定义在代码段的后面。", line_num);
}
else if (AS_INT_TABLE == assembler_state)
{
error_msg("定义了重复的中断向量列表。", line_num);
}
assembler_state = AS_INT_TABLE;
}
// 解析代码段开始标志
void parse_code_section_keyword(int line_num)
{
// 代码段标志
if (AS_DATA == assembler_state)
{
error_msg("代码段不能定义在数据段的后面。", line_num);
}
else if (AS_TEXT == assembler_state)
{
error_msg("定义了重复的代码段。", line_num);
}
//若当前地址小于0x10,则补充空行
for (; machine_code_address < 0x10;)
{
line_database[line_count].line_num = line_num;
line_database[line_count].address = machine_code_address;
machine_code_address++;
machine_code_old_address++;
}
// 代码段的起始地址为0x10
assembler_state = AS_TEXT;
}
// 解析数据段开始标志
void parse_data_section_keyword(int line_num)
{
// 数据段标志
if (AS_DATA == assembler_state)
{
error_msg("定义了重复的数据段。", line_num);
}
else if (AS_BEGIN == assembler_state)
{
error_msg("数据段不能定义在代码段的前面。", line_num);
}
assembler_state = AS_DATA;
}
// 定义关键字和解析函数的对应关系
typedef void(*PARSE_FUNCTION)(int line_num);
struct KEYWORD_FUNCTION_ENTRY
{
const char** keyword;
PARSE_FUNCTION parse_function;
};
//
// 必须将关键字及其解析函数放在下面的表中。从而可以使用“表驱动”的编程模式。
//
struct KEYWORD_FUNCTION_ENTRY keyword_function_table[] =
{
{ NULL, NULL } // 未用
,{ &int_table_section_keyword, parse_int_table_section_keyword }
,{ &code_section_keyword, parse_code_section_keyword }
,{ &data_section_keyword, parse_data_section_keyword }
,{ &mov_instruction_keyword, parse_mov }
,{ &jmp_instruction_keyword, parse_jmp }
,{ &add_instruction_keyword, parse_add }
,{ &adc_instruction_keyword, parse_adc }
,{ &sub_instruction_keyword, parse_sub }
,{ &sbb_instruction_keyword, parse_sbb }
,{ &and_instruction_keyword, parse_and }
,{ &or_instruction_keyword, parse_or }
,{ &jc_instruction_keyword, parse_jc }
,{ &jz_instruction_keyword, parse_jz }
,{ &je_instruction_keyword, parse_jz }
,{ &jnz_instruction_keyword, parse_jnz }
,{ &jne_instruction_keyword, parse_jnz }
,{ &call_instruction_keyword, parse_call }
,{ &push_instruction_keyword, parse_push }
,{ &pop_instruction_keyword, parse_pop }
,{ &in_instruction_keyword, parse_in }
,{ &out_instruction_keyword, parse_out }
,{ &ret_instruction_keyword, parse_ret }
,{ &shr_instruction_keyword, parse_shr }
,{ &shl_instruction_keyword, parse_shl }
,{ &rcr_instruction_keyword, parse_rcr }
,{ &rcl_instruction_keyword, parse_rcl }
,{ &sal_instruction_keyword, parse_sal }
,{ &sar_instruction_keyword, parse_sar }
,{ &rol_instruction_keyword, parse_rol }
,{ &ror_instruction_keyword, parse_ror }
,{ &not_instruction_keyword, parse_not }
,{ &iret_instruction_keyword, parse_iret }
,{ &nop_instruction_keyword, parse_nop }
,{ &int_instruction_keyword, parse_int }
,{ &lea_instruction_keyword, parse_lea }
,{ &inc_instruction_keyword, parse_inc }
,{ &dec_instruction_keyword, parse_dec }
,{ &cmp_instruction_keyword, parse_cmp }
,{ &cli_instruction_keyword, parse_cli }
,{ &sti_instruction_keyword, parse_sti }
,{ &al_register_keyword, NULL }
,{ &bl_register_keyword, NULL }
,{ &cl_register_keyword, NULL }
,{ &dl_register_keyword, NULL }
,{ &sp_register_keyword, NULL }
,{ &bp_register_keyword, NULL }
,{ &si_register_keyword, NULL }
,{ &di_register_keyword, NULL }
,{ &cs_register_keyword, NULL }
,{ &ds_register_keyword, NULL }
,{ &ss_register_keyword, NULL }
,{ &es_register_keyword, NULL }
,{ &al_register_indirect_keyword, NULL }
,{ &bl_register_indirect_keyword, NULL }
,{ &cl_register_indirect_keyword, NULL }
,{ &dl_register_indirect_keyword, NULL }
,{ &sp_register_indirect_keyword, NULL }
,{ &bp_register_indirect_keyword, NULL }
,{ &si_register_indirect_keyword, NULL }
,{ &di_register_indirect_keyword, NULL }
,{ &cs_register_indirect_keyword, NULL }
,{ &ds_register_indirect_keyword, NULL }
,{ &ss_register_indirect_keyword, NULL }
,{ &es_register_indirect_keyword, NULL }
};
// 判断是否是一个关键字。返回0,不是关键字;返回非0,是关键字,并且返回值就是关键字在表中的下标。
int match_keyword(const char* token)
{
int i;
for (i = 1; i < sizeof(keyword_function_table) / sizeof(keyword_function_table[0]); i++)
{
if (stricmp(token, *keyword_function_table[i].keyword) == 0)
{
return i;
}
}
return 0;
}
// 判断是否是一个符号
int is_symbol(const char* token, int line_num)
{
int i;
char symbol_name[MAX_SYMBOL_LENGTH];
// 最后一个字符必须是冒号
if (token[strlen(token) - 1] != ':')
{
return 0;
}
// 第一个字符必须是字母或者下划线
if (token[0] != '_' && !isalpha(token[0]))
{
return 0;
}
// 后面的字符必须是字母、数字、下划线
for (i = 0; i < (int)strlen(token) - 2; i++)
{
if (token[i] != '_' && !isalpha(token[i]) && !isdigit(token[i]))
{
return 0;
}
}
// 不能与关键字相同
strcpy(symbol_name, token);
symbol_name[strlen(symbol_name) - 1] = 0;
if (match_keyword(symbol_name) != 0)
{
error_msg_keyword_symbol(symbol_name, line_num);
}
return 1;
}
// 判断是否是一个中断向量
int is_int_vector(const char* token, int line_num)
{
int i;
char vector_name[MAX_SYMBOL_LENGTH];
// 第一个字符必须是字母或者下划线
if (token[0] != '_' && !isalpha(token[0]))
{
return 0;
}
// 后面的字符必须是字母、数字、下划线
for (i = 0; i < (int)strlen(token) - 2; i++)
{
if (token[i] != '_' && !isalpha(token[i]) && !isdigit(token[i]))
{
return 0;
}
}
// 不能与关键字相同
strcpy(vector_name, token);
if (match_keyword(vector_name) != 0)
{
error_msg_keyword_int_vector(vector_name, line_num);
}
return 1;
}
// 输出版本信息
void version_msg()
{
printf(
"Engintime 8086 汇编器 [版本 2.0]\n"
);
}
// 输出帮助信息
void help_msg()
{
printf(
"Engintime 8086 汇编器。\n\n"
"用法:\n\n"
" dmasm.exe assembly_file_name [options]\n\n"
"选项:\n\n"
" -g debug_file_name\t指定生成的调试信息文件路径。\n"
" -h\t\t\t打印此帮助信息。\n"
" -l list_file_name\t指定生成的列表文件路径。\n"
" -o target_file_name\t指定生成的目标文件路径。若未指定,默认生成 a.obj 文件。\n"
" -v\t\t\t打印版本信息。\n"
);
printf("\n");
version_msg();
exit(1);
}
void argument_error_msg()
{
printf("命令行参数错误。\n\n");
help_msg();
}
// 处理器用户输入的命令行参数
void process_argument(int argc, char* argv[])
{
int i;
// argv[0] 是 "easm.exe",所以可以忽略。
for (i = 1; i < argc; i++)
{
if (strcmp(argv[i], "-v") == 0)
{
version_msg();
exit(1);
}
else if (strcmp(argv[i], "-h") == 0)
{
help_msg();
}
else if (strcmp(argv[i], "-o") == 0)
{
if (i + 1 < argc)
{
i++;
target_file_name = argv[i];
}
else
{
argument_error_msg();
}
}
else if (strcmp(argv[i], "-l") == 0)
{
if (i + 1 < argc)
{
i++;
list_file_name = argv[i];
}
else
{
argument_error_msg();
}
}
else if (strcmp(argv[i], "-g") == 0)
{
if (i + 1 < argc)
{
i++;
dbg_file_name = argv[i];
}
else
{
argument_error_msg();
}
}
else if (NULL == assembly_file_name && argv[i][0] != '-')
{
// 输入的汇编源代码文件路径。
assembly_file_name = argv[i];
}
else
{
argument_error_msg();
}
}
//
// 如果命令行参数中没有指定输入的汇编文件,就打印错误信息后退出
//
if (NULL == assembly_file_name)
{
printf("命令行参数错误。没有指定汇编源代码文件的路径。\n");
help_msg();
}
}
// 将一个字符串写入二进制文件中。先将字符串长度写入文件,然后将字符串中的
// 每个字符依次写入文件,不包括字符串末尾的 0.
void write_string_to_binary_file(const char* str, FILE* fp)
{
int str_length;
if (str != NULL)
{
str_length = strlen(str);
fwrite(&str_length, 1, sizeof(str_length), fp);
fwrite(str, 1, str_length, fp);
}
else
{
str_length = 0;
fwrite(&str_length, 1, sizeof(str_length), fp);
}
}
int main(int argc, char* argv[])
{
FILE* fp;
char* token;
char line[MAX_LINE_LENGTH];
int i, j;
int line_num = 1; // 行号从第一行开始计数
int keyword_index;
//
// 处理命令行参数
//
process_argument(argc, argv);
//
// 打开汇编源代码文件
//
fp = fopen(assembly_file_name, "r");
if (NULL == fp)
{
printf("无法打开源代码文件 %s\n", assembly_file_name);
return 1;
}
//////////////////////////////////////////////////////////////////////////
// 第一遍扫描
version_msg();
printf("\n正在汇编 %s...\n", assembly_file_name);
//
// 一次读取一行文本,同时记录所有的代码行信息
//
while (fgets(line, sizeof(line), fp) != NULL)
{
//
// 将一行代码的信息记录到代码行数据库中
//
strcpy(line_database[line_count].line_string, line);
line_database[line_count].line_num = line_num;
line_database[line_count].address = machine_code_address;
//
// 将代码行中的注释剥离
//
line[strcspn(line, ";")] = 0;
//
// 开始解析代码行
//
token = strtok(line, delimit_char);
if (NULL == token)
{
// 如果是空行,不做任何处理
}
else if ((keyword_index = match_keyword(token)) != 0
&& keyword_function_table[keyword_index].parse_function != NULL)
{
// 根据关键字进行相应的处理
keyword_function_table[keyword_index].parse_function(line_num);
}
else if (is_int_vector(token, line_num))
{
// 必须首先判断是否是中断向量,然后再判断是否是标号。因为判断标号的时候会删除最后一个标志字符“:”,而中断向量名称后是没有冒号的
// 中断向量
parse_int_vector(token, line_num);
// 判断符号
if (is_symbol(token, line_num))
{
// 处理符号
parse_symbol(token, line_num);
}
}
else
{
error_msg("无法识别的代码行。", line_num);
}
//
// 补充代码行数据库信息
//
line_database[line_count].machine_code_count = machine_code_address - machine_code_old_address;
machine_code_old_address = machine_code_address;
//
// 检查机器码地址是否超过了最大地址,若超过则报错(一个地址单元存储一个字节机器码)
//
//
if (MAX_MACHINE_CODE_BYTE_COUNT == machine_code_address)
{
sprintf(formated_msg, "汇编代码的机器码过多,最多只能有 %d 个字节机器码。", MAX_MACHINE_CODE_BYTE_COUNT);
error_msg(formated_msg, -1);
}
//
// 记录产生了机器码的代码行数量
//
if (line_database[line_count].machine_code_count != 0)
{
machine_code_line_count++;
}
//
// 增加行号
//
line_count++;
line_num++;
if (line_count == MAX_LINE_COUNT)
{
sprintf(formated_msg, "汇编文件中的代码行过多,最多只能有 %d 行代码。", MAX_LINE_COUNT);
error_msg(formated_msg, -1);
}
}
fclose(fp);
//////////////////////////////////////////////////////////////////////////
// 第二遍扫描
//
// 根据符号表更新重定位表
//
for (i = 0; i < reallocate_count; i++)
{
for (j = 0; j < symbol_count; j++)
{
if (stricmp(symbol_table[j].name, reallocate_table[i].symbol_name) == 0)
{
machine_code[reallocate_table[i].address] = (BYTE)symbol_table[j].address;
symbol_table[j].ref_count++;
break;
}
}
if (j == symbol_count)
{
// 重定位表中使用的符号在符号表中未定义,报错
sprintf(formated_msg, "使用了未定义的符号 %s。", reallocate_table[i].symbol_name);
error_msg(formated_msg, reallocate_table[i].line_num);
}
}
//
// 如果存在未引用的符号,输出警告信息。
//
for (i = 0; i < symbol_count; i++)
{
if (0 == symbol_table[i].ref_count)
{
warning_msg_unref_symbol(symbol_table[i].name, symbol_table[i].line_num);
}
}
//////////////////////////////////////////////////////////////////////////
// 产生各种输出文件
//
// 将机器码写入二进制文件
//
if (NULL == target_file_name)
{
target_file_name = "a.obj";
}
fp = fopen(target_file_name, "wb");
if (NULL == fp)
{
printf("无法打开输出文件 %s\n", target_file_name);
return 1;
}
fwrite(machine_code, 1, machine_code_address, fp);
fclose(fp);
printf("\n生成目标文件 %s\n", target_file_name);
//
// 将代码行数据库中的信息写入列表文件
//
if (list_file_name != NULL)
{
fp = fopen(list_file_name, "w");
if (NULL == fp)
{
printf("无法打开列表文件 %s\n", list_file_name);
return 1;
}
for (i = 0; i < line_count; i++)
{
// 行号
fprintf(fp, "%04d ", line_database[i].line_num);
// 地址和机器码
if (line_database[i].machine_code_count > 0)
{
fprintf(fp, "%02X ", line_database[i].address);
for (j = 0; j < line_database[i].machine_code_count; j++)
{
// 确保每行最多写三个字节的机器码
if (j != 0 && j % 3 == 0)
{
if (3 == j)
{
fprintf(fp, " ");
}
else
{
fprintf(fp, "\n ");
}
}
fprintf(fp, "%02X ", machine_code[line_database[i].address + j]);
if (2 == j)
{
fprintf(fp, " ");
fprintf(fp, line_database[i].line_string);
}
}
if (1 == j)
{
// 单字节指令
fprintf(fp, " ");
fprintf(fp, line_database[i].line_string);
}
else if (2 == j)
{
fprintf(fp, " ");
fprintf(fp, line_database[i].line_string);
}
else if (j > 3)
{
fprintf(fp, "\n");
}
}
else
{
fprintf(fp, " ");
// 源代码
fprintf(fp, line_database[i].line_string);
}
}
fclose(fp);
printf("生成列表文件 %s\n", list_file_name);
}
//
// 将代码行数据库中的信息写入二进制的调试信息文件。
//
// 调试信息的基本格式为:
// 魔数(4字节),固定不可改变
// 版本号(4字节),固定不可改变
// 源代码文件绝对路径字符串长度(4字节)
// 源代码文件绝对路径字符串(不包括字符串结尾的0)
// 列表文件绝对路径字符串长度(4字节)
// 列表文件绝对路径字符串(不包括字符串结尾的0)
//
// 代码行数据库中元素的数量(4字节)
// 代码行数据库中的所有元素
//
// 符号表元素的数量(4字节)
// 符号表中的所有元素
//
if (dbg_file_name != NULL)
{
fp = fopen(dbg_file_name, "wb");
if (NULL == fp)
{
printf("无法打开调试信息文件 %s\n", dbg_file_name);
return 1;
}
// 魔数
fwrite(&dbg_file_magic, 1, sizeof(dbg_file_magic), fp);
// 版本号
fwrite(&dbg_file_version, 1, sizeof(dbg_file_version), fp);
// 源代码文件路径
write_string_to_binary_file(assembly_file_name, fp);
// 列表文件路径
write_string_to_binary_file(list_file_name, fp);
// 代码行数据库中的所有元素
fwrite(&machine_code_line_count, 1, sizeof(machine_code_line_count), fp);
for (i = 0; i < line_count; i++)
{
// 跳过没有产生机器码的代码行
if (0 == line_database[i].machine_code_count)
{
continue;
}
fwrite(&line_database[i].line_num, 1, sizeof(unsigned long), fp);
fwrite(&line_database[i].address, 1, sizeof(unsigned long), fp);
fwrite(&line_database[i].machine_code_count, 1, sizeof(unsigned long), fp);
fwrite(&line_database[i].flag, 1, sizeof(unsigned long), fp);
}
// 符号表中的所有元素
fwrite(&symbol_count, 1, sizeof(symbol_count), fp);
for (i = 0; i < symbol_count; i++)
{
write_string_to_binary_file(symbol_table[i].name, fp);
fwrite(&symbol_table[i].address, 1, sizeof(unsigned long), fp);
fwrite(&symbol_table[i].machine_code_count, 1, sizeof(int), fp);
fwrite(&symbol_table[i].line_num, 1, sizeof(int), fp);
}
fclose(fp);
printf("生成调试信息文件 %s\n", dbg_file_name);
}
return 0;
}
添加文件
;利用DAC 0832 产生一个正向锯齿波电压,DAC0832工作在单缓冲方式,端口地址为0x80。
.text
mov dl, 0x80
mov al, 0
out dl,al
NEXT:
add al, 0x40
out dl, al
jmp NEXT
@echo off
dmasm.exe ram.asm -o ram.rxm -l ram.lst -g ram.dbg
pause
添加文件
0001 ;利用DAC 0832 产生一个正向锯齿波电压,DAC0832工作在单缓冲方式,端口地址为0x80。
0002 .text
0003
0004 10 01 03 80 mov dl, 0x80
0005 13 01 00 00 mov al, 0
0006 16 4D 03 out dl,al
0007
0008 NEXT:
0009 18 0E 00 40 add al, 0x40
0010 1B 4D 03 out dl, al
0011 1D 57 18 jmp NEXT
0012
0013
添加文件
# 说明
数/模转换实验
# 原理图
![raw svg](DAC0832_test.dlsche.svg)
![raw svg](top.dlsche.svg)
\ No newline at end of file
添加文件
<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<svg height="4521" version="1.1" width="11039" xmlns="http://www.w3.org/2000/svg">
<text alignment-baseline="after-edge" fill="#800000" font-family="微软雅黑" font-size="200" font-weight="700" text-anchor="start" x="27" y="3744">DBUS[7..0]</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="微软雅黑" font-size="200" font-weight="700" text-anchor="start" x="57" y="974">ABUS[7..0]</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="微软雅黑" font-size="65" font-weight="700" text-anchor="start" x="1777" y="2444">CLK</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1167" x2="1267" y1="2444" y2="2444"/>
<rect fill="#ffffb0" height="100" stroke="#800000" stroke-width="5" width="100" x="1067" y="2394"/>
<polyline fill="none" points="1077 2344, 1157 2344" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1117 2344, 1117 2394" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1087 2474, 1117 2474, 1117 2414, 1147 2414" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="1"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="180" font-weight="700" text-anchor="start" x="687" y="2331">CLOCK</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="977" y="2454">SCLK</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="微软雅黑" font-size="65" font-weight="700" text-anchor="start" x="977" y="2564">Key = C</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="微软雅黑" font-size="90" font-weight="700" text-anchor="start" x="1447" y="1664">RESET</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1347" x2="1447" y1="1664" y2="1664"/>
<rect fill="#ffffb0" height="100" stroke="#800000" stroke-width="5" width="100" x="1247" y="1614"/>
<polyline fill="none" points="1257 1564, 1337 1564" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1297 1564, 1297 1614" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1267 1694, 1297 1694, 1297 1634, 1327 1634" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="1"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="180" font-weight="700" text-anchor="start" x="1027" y="1541">RESET</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1157" y="1674">SCLK</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="微软雅黑" font-size="180" font-weight="700" text-anchor="start" x="997" y="1964">Key = R</text>
<polyline fill="none" points="4817 44, 4817 4474" stroke="#000000" stroke-dasharray="200,100" stroke-linecap="round" stroke-linejoin="round" stroke-width="50"/>
<rect fill="#80ff80" height="1700" stroke="#800000" stroke-width="1" width="700" x="3217" y="1444"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="250" font-weight="700" text-anchor="start" x="3217" y="1344">8086</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3217" y="1394">8086\8086.dlsche</text>
<polygon fill="#ffff80" points="3217 1544, 3242 1519, 3292 1519, 3317 1544, 3292 1569, 3242 1569, 3217 1544" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="1544">CLK</text>
<polygon fill="#ffff80" points="3217 1644, 3242 1619, 3292 1619, 3317 1644, 3292 1669, 3242 1669, 3217 1644" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="1644">RESET</text>
<polygon fill="#ffff80" points="3217 1744, 3242 1719, 3292 1719, 3317 1744, 3292 1769, 3242 1769, 3217 1744" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="1744">INTR</text>
<polygon fill="#ffff80" points="3217 1844, 3242 1819, 3292 1819, 3317 1844, 3292 1869, 3242 1869, 3217 1844" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="1844">READY</text>
<polygon fill="#ffff80" points="3217 1944, 3242 1919, 3292 1919, 3317 1944, 3292 1969, 3242 1969, 3217 1944" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="1944">HOLD</text>
<polygon fill="#ffff80" points="3217 2044, 3242 2019, 3292 2019, 3317 2044, 3292 2069, 3242 2069, 3217 2044" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="2044">NMI</text>
<polygon fill="#ffff80" points="3217 2144, 3242 2119, 3292 2119, 3317 2144, 3292 2169, 3242 2169, 3217 2144" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="2144">TESET</text>
<polygon fill="#ffff80" points="3217 2244, 3242 2219, 3292 2219, 3317 2244, 3292 2269, 3242 2269, 3217 2244" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="2244">D0</text>
<polygon fill="#ffff80" points="3217 2344, 3242 2319, 3292 2319, 3317 2344, 3292 2369, 3242 2369, 3217 2344" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="2344">D1</text>
<polygon fill="#ffff80" points="3217 2444, 3242 2419, 3292 2419, 3317 2444, 3292 2469, 3242 2469, 3217 2444" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="2444">D2</text>
<polygon fill="#ffff80" points="3217 2544, 3242 2519, 3292 2519, 3317 2544, 3292 2569, 3242 2569, 3217 2544" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="2544">D3</text>
<polygon fill="#ffff80" points="3217 2644, 3242 2619, 3292 2619, 3317 2644, 3292 2669, 3242 2669, 3217 2644" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="2644">D4</text>
<polygon fill="#ffff80" points="3217 2744, 3242 2719, 3292 2719, 3317 2744, 3292 2769, 3242 2769, 3217 2744" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="2744">D5</text>
<polygon fill="#ffff80" points="3217 2844, 3242 2819, 3292 2819, 3317 2844, 3292 2869, 3242 2869, 3217 2844" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="2844">D6</text>
<polygon fill="#ffff80" points="3217 2944, 3242 2919, 3292 2919, 3317 2944, 3292 2969, 3242 2969, 3217 2944" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3327" y="2944">D7</text>
<polygon fill="#ffff80" points="3917 1544, 3892 1519, 3842 1519, 3817 1544, 3842 1569, 3892 1569, 3917 1544" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="1544">A0</text>
<polygon fill="#ffff80" points="3917 1644, 3892 1619, 3842 1619, 3817 1644, 3842 1669, 3892 1669, 3917 1644" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="1644">A1</text>
<polygon fill="#ffff80" points="3917 1744, 3892 1719, 3842 1719, 3817 1744, 3842 1769, 3892 1769, 3917 1744" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="1744">A2</text>
<polygon fill="#ffff80" points="3917 1844, 3892 1819, 3842 1819, 3817 1844, 3842 1869, 3892 1869, 3917 1844" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="1844">A3</text>
<polygon fill="#ffff80" points="3917 1944, 3892 1919, 3842 1919, 3817 1944, 3842 1969, 3892 1969, 3917 1944" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="1944">A4</text>
<polygon fill="#ffff80" points="3917 2044, 3892 2019, 3842 2019, 3817 2044, 3842 2069, 3892 2069, 3917 2044" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="2044">A5</text>
<polygon fill="#ffff80" points="3917 2144, 3892 2119, 3842 2119, 3817 2144, 3842 2169, 3892 2169, 3917 2144" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="2144">A6</text>
<polygon fill="#ffff80" points="3917 2244, 3892 2219, 3842 2219, 3817 2244, 3842 2269, 3892 2269, 3917 2244" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="2244">A7</text>
<polygon fill="#ffff80" points="3917 2344, 3892 2319, 3842 2319, 3817 2344, 3842 2369, 3892 2369, 3917 2344" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3687" y="2344">WR_OUT</text>
<polygon fill="#ffff80" points="3917 2444, 3892 2419, 3842 2419, 3817 2444, 3842 2469, 3892 2469, 3917 2444" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3687" y="2444">READ_OUT</text>
<polygon fill="#ffff80" points="3917 2544, 3892 2519, 3842 2519, 3817 2544, 3842 2569, 3892 2569, 3917 2544" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="2544">MIO</text>
<polygon fill="#ffff80" points="3917 2644, 3892 2619, 3842 2619, 3817 2644, 3842 2669, 3892 2669, 3917 2644" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="2644">INTA</text>
<polygon fill="#ffff80" points="3917 2744, 3892 2719, 3842 2719, 3817 2744, 3842 2769, 3892 2769, 3917 2744" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="2744">HLDA</text>
<polygon fill="#ffff80" points="3917 2844, 3892 2819, 3842 2819, 3817 2844, 3842 2869, 3892 2869, 3917 2844" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="2844">ALE</text>
<polygon fill="#ffff80" points="3917 2944, 3892 2919, 3842 2919, 3817 2944, 3842 2969, 3892 2969, 3917 2944" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="2944">DEN</text>
<polygon fill="#ffff80" points="3917 3044, 3892 3019, 3842 3019, 3817 3044, 3842 3069, 3892 3069, 3917 3044" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="3707" y="3044">DTR</text>
<polyline fill="none" points="3217 2244, 2867 2244" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="3217 2944, 2867 2944" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="2817" x2="2867" y1="2994" y2="2944"/>
<polyline fill="none" points="2867 2344, 3217 2344" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="2867 2444, 3217 2444" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="2867 2544, 3217 2544" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="2867 2644, 3217 2644" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="2867 2744, 3217 2744" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="2867 2844, 3217 2844" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="2817" x2="2867" y1="2894" y2="2844"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="2817" x2="2867" y1="2794" y2="2744"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="2817" x2="2867" y1="2694" y2="2644"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="2817" x2="2867" y1="2594" y2="2544"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="2817" x2="2867" y1="2494" y2="2444"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="2817" x2="2867" y1="2394" y2="2344"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="2817" x2="2867" y1="2294" y2="2244"/>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="2867" y="2244">DBUS0</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="2867" y="2344">DBUS1</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="2867" y="2444">DBUS2</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="2867" y="2544">DBUS3</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="2867" y="2644">DBUS4</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="2867" y="2744">DBUS5</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="2867" y="2844">DBUS6</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="2867" y="2944">DBUS7</text>
<polyline fill="none" points="3907 1544, 4157 1544" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="3917 1644, 4167 1644" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="3917 1744, 4167 1744" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="3917 1844, 4167 1844" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="3917 1944, 4167 1944" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="3917 2044, 4167 2044" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="3917 2144, 4167 2144" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="3917 2244, 4167 2244" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="4157" x2="4207" y1="1544" y2="1494"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="4167" x2="4217" y1="1644" y2="1594"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="4167" x2="4217" y1="1744" y2="1694"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="4167" x2="4217" y1="1844" y2="1794"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="4167" x2="4217" y1="1944" y2="1894"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="4167" x2="4217" y1="2044" y2="1994"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="4167" x2="4217" y1="2144" y2="2094"/>
<line stroke="#000080" stroke-linecap="round" stroke-width="5" x1="4167" x2="4217" y1="2244" y2="2194"/>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="4007" y="1544">ABUS0</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="4017" y="1644">ABUS1</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="4017" y="1744">ABUS2</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="4017" y="1844">ABUS3</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="4017" y="1944">ABUS4</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="4017" y="2044">ABUS5</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="4017" y="2144">ABUS6</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="4017" y="2244">ABUS7</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1167" x2="1267" y1="2644" y2="2644"/>
<rect fill="#ffffb0" height="100" stroke="#800000" stroke-width="5" width="100" x="1067" y="2594"/>
<polyline fill="none" points="1077 2654, 1087 2654, 1087 2624, 1107 2624, 1107 2654, 1127 2654, 1127 2624, 1147 2624, 1147 2654" stroke="#000080" stroke-linecap="round" stroke-linejoin="round" stroke-width="1"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1107" y="2584">C1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1063" y="2740">CLOCK11</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1207" y="2624">100Hz</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1167" x2="1267" y1="2844" y2="2844"/>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="30" font-weight="400" text-anchor="start" x="1108" y="2864">1</text>
<rect fill="#ffffff" fill-opacity="0.5" height="60" stroke="#800000" stroke-width="5" width="100" x="1067" y="2814"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1111" y="2805">2</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="998" y="2866">DCT</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="1068" y="2917">Key = S</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1627" x2="1567" y1="2444" y2="2444"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1707" x2="1767" y1="2444" y2="2444"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1667" x2="1667" y1="2484" y2="2544"/>
<circle cx="1667" cy="2476" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<polygon fill="#ffffff" fill-opacity="0.5" points="1627 2394, 1627 2494, 1707 2444, 1627 2394" stroke="#000000" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1677" y="2364">U3</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1627" y="2394">NBUFFER</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1627" x2="1567" y1="2644" y2="2644"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1707" x2="1767" y1="2644" y2="2644"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1667" x2="1667" y1="2684" y2="2744"/>
<circle cx="1667" cy="2676" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<polygon fill="#ffffff" fill-opacity="0.5" points="1627 2594, 1627 2694, 1707 2644, 1627 2594" stroke="#000000" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1677" y="2564">U4</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1627" y="2594">NBUFFER</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1527" x2="1467" y1="2544" y2="2544"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="1607" x2="1667" y1="2544" y2="2544"/>
<circle cx="1603" cy="2544" fill="none" r="5" stroke="#000000" stroke-width="5"/>
<polygon fill="#ffffff" fill-opacity="0.5" points="1527 2494, 1527 2594, 1597 2544, 1527 2494" stroke="#000000" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1547" y="2508">U5</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="1527" y="2640">NOT</text>
<rect fill="#80ff80" height="600" stroke="#800000" stroke-width="1" width="700" x="5517" y="2544"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="250" font-weight="700" text-anchor="start" x="5517" y="2444">MEM</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="5517" y="2494">MEM\MEM.dlsche</text>
<polygon fill="#ffff80" points="5517 2644, 5542 2619, 5592 2619, 5617 2644, 5592 2669, 5542 2669, 5517 2644" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="5627" y="2644">WR_OUT</text>
<polygon fill="#ffff80" points="5517 2744, 5542 2719, 5592 2719, 5617 2744, 5592 2769, 5542 2769, 5517 2744" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="5627" y="2744">CLK</text>
<polygon fill="#ffff80" points="5517 2844, 5542 2819, 5592 2819, 5617 2844, 5592 2869, 5542 2869, 5517 2844" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="5627" y="2844">MIO</text>
<polygon fill="#ffff80" points="5517 2944, 5542 2919, 5592 2919, 5617 2944, 5592 2969, 5542 2969, 5517 2944" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="5627" y="2944">READ_OUT</text>
<polygon fill="#ffff80" points="5517 3044, 5542 3019, 5592 3019, 5617 3044, 5592 3069, 5542 3069, 5517 3044" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="5627" y="3044">ABUS[7..0]</text>
<polygon fill="#ffff80" points="6217 2644, 6192 2619, 6142 2619, 6117 2644, 6142 2669, 6192 2669, 6217 2644" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="6007" y="2644">DBUS[7..0]</text>
<polyline fill="none" points="4217 2194, 4217 974" stroke="#ff8057" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<polyline fill="none" points="5517 3044, 5317 3044, 5317 974" stroke="#ff8057" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<polyline fill="none" points="7417 2544, 7217 2544, 7217 974" stroke="#ff8057" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<polyline fill="none" points="2817 2294, 2817 3744" stroke="#000080" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<polyline fill="none" points="6217 2644, 6417 2644, 6417 3744" stroke="#000080" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<rect fill="#80ff80" height="1100" stroke="#800000" stroke-width="1" width="700" x="7417" y="2044"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="250" font-weight="700" text-anchor="start" x="7417" y="1944">IO</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7417" y="1994">IO\IO.dlsche</text>
<polygon fill="#ffff80" points="7417 2144, 7442 2119, 7492 2119, 7517 2144, 7492 2169, 7442 2169, 7417 2144" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7527" y="2144">MIO</text>
<polygon fill="#ffff80" points="7417 2244, 7442 2219, 7492 2219, 7517 2244, 7492 2269, 7442 2269, 7417 2244" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7527" y="2244">WR_OUT</text>
<polygon fill="#ffff80" points="7417 2344, 7442 2319, 7492 2319, 7517 2344, 7492 2369, 7442 2369, 7417 2344" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7527" y="2344">READ_OUT</text>
<polygon fill="#ffff80" points="7417 2444, 7442 2419, 7492 2419, 7517 2444, 7492 2469, 7442 2469, 7417 2444" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7527" y="2444">MIO</text>
<polygon fill="#ffff80" points="7417 2544, 7442 2519, 7492 2519, 7517 2544, 7492 2569, 7442 2569, 7417 2544" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7527" y="2544">A[7..0]</text>
<polygon fill="#ffff80" points="8117 2144, 8092 2119, 8042 2119, 8017 2144, 8042 2169, 8092 2169, 8117 2144" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7907" y="2144">IOW</text>
<polygon fill="#ffff80" points="8117 2244, 8092 2219, 8042 2219, 8017 2244, 8042 2269, 8092 2269, 8117 2244" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7907" y="2244">IOR</text>
<polygon fill="#ffff80" points="8117 2344, 8092 2319, 8042 2319, 8017 2344, 8042 2369, 8092 2369, 8117 2344" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7907" y="2344">CS0</text>
<polygon fill="#ffff80" points="8117 2444, 8092 2419, 8042 2419, 8017 2444, 8042 2469, 8092 2469, 8117 2444" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7907" y="2444">CS1</text>
<polygon fill="#ffff80" points="8117 2544, 8092 2519, 8042 2519, 8017 2544, 8042 2569, 8092 2569, 8117 2544" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7907" y="2544">CS2</text>
<polygon fill="#ffff80" points="8117 2644, 8092 2619, 8042 2619, 8017 2644, 8042 2669, 8092 2669, 8117 2644" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7907" y="2644">CS3</text>
<polygon fill="#ffff80" points="8117 2744, 8092 2719, 8042 2719, 8017 2744, 8042 2769, 8092 2769, 8117 2744" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7907" y="2744">CS4</text>
<polygon fill="#ffff80" points="8117 2844, 8092 2819, 8042 2819, 8017 2844, 8042 2869, 8092 2869, 8117 2844" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7907" y="2844">CS5</text>
<polygon fill="#ffff80" points="8117 2944, 8092 2919, 8042 2919, 8017 2944, 8042 2969, 8092 2969, 8117 2944" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7907" y="2944">CS6</text>
<polygon fill="#ffff80" points="8117 3044, 8092 3019, 8042 3019, 8017 3044, 8042 3069, 8092 3069, 8117 3044" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="7907" y="3044">CS7</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="275" font-weight="700" text-anchor="start" x="77" y="344">实验七:数/模转换器DAC0832</text>
<polyline fill="none" points="57 974, 8117 974" stroke="#ff8057" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<polyline fill="none" points="27 3744, 8117 3744" stroke="#000080" stroke-linecap="round" stroke-linejoin="round" stroke-width="20"/>
<polyline fill="none" points="1767 2444, 1867 2444, 1867 2644, 1767 2644" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1567 2644, 1267 2644" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1267 2844, 1667 2844, 1667 2744" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1467 2544, 1467 2844" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="1567 2444, 1267 2444" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<rect fill="#80ff80" height="1000" stroke="#800000" stroke-width="1" width="700" x="9017" y="1944"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="175" font-weight="700" text-anchor="start" x="9017" y="1844">DAC0832</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9017" y="1894">DAC0832\DAC0832.dlsche</text>
<polygon fill="#ffff80" points="9017 2044, 9042 2019, 9092 2019, 9117 2044, 9092 2069, 9042 2069, 9017 2044" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9127" y="2044">CS</text>
<polygon fill="#ffff80" points="9017 2144, 9042 2119, 9092 2119, 9117 2144, 9092 2169, 9042 2169, 9017 2144" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9127" y="2144">WR1</text>
<polygon fill="#ffff80" points="9017 2244, 9042 2219, 9092 2219, 9117 2244, 9092 2269, 9042 2269, 9017 2244" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9127" y="2244">AGND</text>
<polygon fill="#ffff80" points="9017 2344, 9042 2319, 9092 2319, 9117 2344, 9092 2369, 9042 2369, 9017 2344" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9127" y="2344">D3</text>
<polygon fill="#ffff80" points="9017 2444, 9042 2419, 9092 2419, 9117 2444, 9092 2469, 9042 2469, 9017 2444" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9127" y="2444">D2</text>
<polygon fill="#ffff80" points="9017 2544, 9042 2519, 9092 2519, 9117 2544, 9092 2569, 9042 2569, 9017 2544" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9127" y="2544">D1</text>
<polygon fill="#ffff80" points="9017 2644, 9042 2619, 9092 2619, 9117 2644, 9092 2669, 9042 2669, 9017 2644" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9127" y="2644">D0</text>
<polygon fill="#ffff80" points="9017 2744, 9042 2719, 9092 2719, 9117 2744, 9092 2769, 9042 2769, 9017 2744" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9127" y="2744">VREF</text>
<polygon fill="#ffff80" points="9017 2844, 9042 2819, 9092 2819, 9117 2844, 9092 2869, 9042 2869, 9017 2844" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9127" y="2844">Rfb</text>
<polygon fill="#ffff80" points="9717 2044, 9692 2019, 9642 2019, 9617 2044, 9642 2069, 9692 2069, 9717 2044" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9507" y="2044">ILE</text>
<polygon fill="#ffff80" points="9717 2144, 9692 2119, 9642 2119, 9617 2144, 9642 2169, 9692 2169, 9717 2144" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9507" y="2144">WR2</text>
<polygon fill="#ffff80" points="9717 2244, 9692 2219, 9642 2219, 9617 2244, 9642 2269, 9692 2269, 9717 2244" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9507" y="2244">XFER</text>
<polygon fill="#ffff80" points="9717 2344, 9692 2319, 9642 2319, 9617 2344, 9642 2369, 9692 2369, 9717 2344" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9507" y="2344">D4</text>
<polygon fill="#ffff80" points="9717 2444, 9692 2419, 9642 2419, 9617 2444, 9642 2469, 9692 2469, 9717 2444" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9507" y="2444">D5</text>
<polygon fill="#ffff80" points="9717 2544, 9692 2519, 9642 2519, 9617 2544, 9642 2569, 9692 2569, 9717 2544" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9507" y="2544">D6</text>
<polygon fill="#ffff80" points="9717 2644, 9692 2619, 9642 2619, 9617 2644, 9642 2669, 9692 2669, 9717 2644" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9507" y="2644">D7</text>
<polygon fill="#ffff80" points="9717 2744, 9692 2719, 9642 2719, 9617 2744, 9642 2769, 9692 2769, 9717 2744" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9507" y="2744">Iout2</text>
<polygon fill="#ffff80" points="9717 2844, 9692 2819, 9642 2819, 9617 2844, 9642 2869, 9692 2869, 9717 2844" stroke="#800000" stroke-width="1"/>
<text alignment-baseline="central" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9507" y="2844">Iout1</text>
<polyline fill="none" points="9717 2044, 9917 2044" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="9917" x2="9917" y1="1994" y2="2044"/>
<polygon fill="#ffffff" fill-opacity="0.5" points="9917 1994, 9967 1944, 9867 1944, 9917 1994" stroke="#000000" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="30" font-weight="700" text-anchor="start" x="9907" y="1984">1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="9907" y="1914">U1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="9847" y="1944">DIGITAL1</text>
<polyline fill="none" points="9717 2344, 9917 2344" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9717 2444, 9917 2444" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9717 2544, 9917 2544" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9717 2644, 9917 2644" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9817" y="2344">DBUS4</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9817" y="2444">DBUS5</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9817" y="2544">DBUS6</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="9817" y="2644">DBUS7</text>
<polyline fill="none" points="9017 2344, 8867 2344" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9017 2444, 8867 2444" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9017 2544, 8867 2544" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9017 2644, 8867 2644" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="8867" y="2344">DBUS3</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="8867" y="2444">DBUS2</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="8867" y="2544">DBUS1</text>
<text alignment-baseline="after-edge" fill="#800000" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="8867" y="2644">DBUS0</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="8617" x2="8617" y1="2824" y2="2744"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="8617" x2="8617" y1="2884" y2="2964"/>
<polyline fill="none" points="8567 2824, 8667 2824" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="8597 2844, 8637 2844" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="8567 2864, 8667 2864" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="8597 2884, 8637 2884" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="8668" y="2816">V1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="8651" y="2922">DC</text>
<text alignment-baseline="after-edge" fill="#000080" font-family="Times New Roman" font-size="25" font-weight="400" text-anchor="start" x="8697" y="2864">5V</text>
<polyline fill="none" points="9017 2744, 8617 2744" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="8617" x2="8617" y1="3344" y2="3244"/>
<polyline fill="none" points="8567 3344, 8667 3344" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="8587 3360, 8647 3360" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="8607 3375, 8627 3375" stroke="#000000" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="8627" y="3294"></text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="8587" y="3424">GND</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="10077" x2="10017" y1="2804" y2="2804"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="10052" y="2804">2</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="10077" x2="10017" y1="2744" y2="2744"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="end" x="10052" y="2744">1</text>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="10177" x2="10237" y1="2774" y2="2774"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="Courier New" font-size="17" font-weight="400" text-anchor="start" x="10202" y="2774">3</text>
<polygon fill="#fffcf8" fill-opacity="0.5" points="10077 2714, 10077 2834, 10177 2774, 10077 2714" stroke="#000000" stroke-width="5"/>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="27" font-weight="700" text-anchor="start" x="10080" y="2821">+</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="微软雅黑" font-size="27" font-weight="700" text-anchor="start" x="10083" y="2760">-</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="10117" y="2734">1</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="10077" y="2884">AMP</text>
<polyline fill="none" points="9717 2844, 9867 2844, 9867 2744, 10017 2744" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9717 2744, 9817 2744, 9817 2804, 10017 2804" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="10237 2774, 10317 2774" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9017 2844, 8917 2844, 8917 3044, 10267 3044, 10267 2774" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="8617 3244, 8617 2964" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9017 2244, 8467 2244, 8467 3144, 8617 3144, 11017 3144, 11017 2774, 10957 2774" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9017 2144, 8117 2144" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9017 2044, 8317 2044, 8317 2344, 8117 2344" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<polyline fill="none" points="9917 2804, 9917 3144" stroke="#0000ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="5"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="10437" x2="10317" y1="2774" y2="2774"/>
<line stroke="#000000" stroke-linecap="round" stroke-width="5" x1="10837" x2="10957" y1="2774" y2="2774"/>
<rect fill="#808080" height="170" stroke="#808080" stroke-width="5" width="400" x="10437" y="2684"/>
<rect fill="#000000" height="100" stroke="#000000" stroke-width="5" width="250" x="10507" y="2724"/>
<text alignment-baseline="central" fill="#00ff00" font-family="微软雅黑" font-size="35" font-weight="700" text-anchor="end" x="10737" y="2774">4.98047</text>
<text alignment-baseline="after-edge" fill="#00ff00" font-family="微软雅黑" font-size="35" font-weight="700" text-anchor="start" x="10767" y="2794">V</text>
<text alignment-baseline="after-edge" fill="#00ff00" font-family="微软雅黑" font-size="35" font-weight="700" text-anchor="start" x="10477" y="2734">+</text>
<text alignment-baseline="after-edge" fill="#00ff00" font-family="微软雅黑" font-size="35" font-weight="700" text-anchor="start" x="10777" y="2734">-</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="10607" y="2676">U2</text>
<text alignment-baseline="after-edge" fill="#000000" font-family="Arial" font-size="25" font-weight="700" text-anchor="start" x="10607" y="2914">V</text>
<circle cx="7217" cy="974" fill="#000080" r="25" stroke="#000080" stroke-width="5"/>
<circle cx="5317" cy="974" fill="#000080" r="25" stroke="#000080" stroke-width="5"/>
<circle cx="4217" cy="974" fill="#000080" r="25" stroke="#000080" stroke-width="5"/>
<circle cx="6417" cy="3744" fill="#000080" r="25" stroke="#000080" stroke-width="5"/>
<circle cx="2817" cy="3744" fill="#000080" r="25" stroke="#000080" stroke-width="5"/>
<circle cx="1467" cy="2844" fill="#0000ff" r="8" stroke="#0000ff" stroke-width="5"/>
<circle cx="8617" cy="3144" fill="#0000ff" r="8" stroke="#0000ff" stroke-width="5"/>
<circle cx="10267" cy="2774" fill="#0000ff" r="8" stroke="#0000ff" stroke-width="5"/>
<circle cx="9917" cy="2804" fill="#0000ff" r="8" stroke="#0000ff" stroke-width="5"/>
<circle cx="9917" cy="3144" fill="#0000ff" r="8" stroke="#0000ff" stroke-width="5"/>
</svg>
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论