mirror of
https://github.com/wwarthen/RomWBW.git
synced 2026-02-07 06:53:13 -06:00
Compare commits
3449 Commits
v2.6
...
v3.6.0-dev
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
2d0ebf49f7 | ||
|
|
7177f1183d | ||
|
|
9d04a7b1df | ||
|
|
6121e80310 | ||
|
|
d6e2e042f8 | ||
|
|
361e9ed83a | ||
|
|
4ee14cbefa | ||
|
|
10b4f98276 | ||
|
|
affc47efc2 | ||
|
|
1195a82ab9 | ||
|
|
2d77d4f036 | ||
|
|
43a835fdde | ||
|
|
22f9c9cef1 | ||
|
|
7e4ce45f9a | ||
|
|
f164ffdc76 | ||
|
|
6684a3e039 | ||
|
|
6202bd244c | ||
|
|
9ba4a7fecd | ||
|
|
130c0590fa | ||
|
|
a11b42f734 | ||
|
|
33f69d0497 | ||
|
|
648c464518 | ||
|
|
a4b8d14e3d | ||
|
|
08f2eb215a | ||
|
|
cf528ef1c1 | ||
|
|
16449bb817 | ||
|
|
e6b3945e42 | ||
|
|
c11ec9f097 | ||
|
|
8983b3642d | ||
|
|
fa4f0c996a | ||
|
|
74cfca470d | ||
|
|
1f6672ebab | ||
|
|
b5f402554c | ||
|
|
ee6cd57f15 | ||
|
|
e43b739ddd | ||
|
|
474a261649 | ||
|
|
2b459b1358 | ||
|
|
5e7009876c | ||
|
|
046c8cc20c | ||
|
|
caf7544219 | ||
|
|
58d0c7add0 | ||
|
|
067363824c | ||
|
|
edaa4e2a03 | ||
|
|
1a38b97e51 | ||
|
|
36dac79faf | ||
|
|
1738bfeb35 | ||
|
|
79180f2a3b | ||
|
|
a51a581d97 | ||
|
|
aee9b4aa87 | ||
|
|
9f2bee08b6 | ||
|
|
ec973d0b3f | ||
|
|
a6f04b8be2 | ||
|
|
cccb51b3c4 | ||
|
|
15f22a0cb0 | ||
|
|
b82910cad8 | ||
|
|
a188add0eb | ||
|
|
641a4d7daf | ||
|
|
d7dc9aafa4 | ||
|
|
072774a147 | ||
|
|
15e44ecd8e | ||
|
|
2eb4e5606c | ||
|
|
15f440ce4d | ||
|
|
1a8f03b322 | ||
|
|
2d2696d22c | ||
|
|
090d26b2af | ||
|
|
e4c55edc02 | ||
|
|
a68ae0cd24 | ||
|
|
45ac5cb3be | ||
|
|
21f7dfc4fb | ||
|
|
d92fb77f11 | ||
|
|
4006bc0224 | ||
|
|
0d5681d2db | ||
|
|
ab9e6d662d | ||
|
|
4fa7bf0117 | ||
|
|
14a9f51efe | ||
|
|
a052b145fe | ||
|
|
1d7b0d970f | ||
|
|
ddeb6ce48b | ||
|
|
b6598cdcc6 | ||
|
|
74f9daaaaa | ||
|
|
dddffac68f | ||
|
|
f03c68c016 | ||
|
|
8c629c637d | ||
|
|
2dba16c62d | ||
|
|
90bb60d423 | ||
|
|
52bf7a56e3 | ||
|
|
0a0f2f8a4b | ||
|
|
aacf98a82a | ||
|
|
42385fd120 | ||
|
|
d754e475c2 | ||
|
|
a75dada16e | ||
|
|
e5a98ec501 | ||
|
|
0a8b4355c9 | ||
|
|
bd6e374d72 | ||
|
|
e4c5f1e1f8 | ||
|
|
a29c6f35c7 | ||
|
|
c5da5b60a8 | ||
|
|
8a5f9eed2d | ||
|
|
5a70c0bd38 | ||
|
|
edfb568c82 | ||
|
|
d35207c7a8 | ||
|
|
347223fa02 | ||
|
|
d259411e72 | ||
|
|
2bb559d29a | ||
|
|
5855dafac6 | ||
|
|
b4fe4dc7e9 | ||
|
|
2269142a04 | ||
|
|
ae3cd27579 | ||
|
|
7dbe9a5abb | ||
|
|
1a955efee6 | ||
|
|
67b89d2a9c | ||
|
|
7d72d8c347 | ||
|
|
8475f29e43 | ||
|
|
7f64871014 | ||
|
|
1ef10c3c14 | ||
|
|
9f15687b03 | ||
|
|
e696dc6c19 | ||
|
|
c8014d1947 | ||
|
|
801ee17487 | ||
|
|
0a35539d1c | ||
|
|
43680193a9 | ||
|
|
7accbc4981 | ||
|
|
9689034523 | ||
|
|
af3401ac5b | ||
|
|
b50913e4c3 | ||
|
|
f99afc3d37 | ||
|
|
744736fa23 | ||
|
|
84770dc29a | ||
|
|
cebeee1157 | ||
|
|
f6b083d835 | ||
|
|
71abbfb8fc | ||
|
|
0932a43fe7 | ||
|
|
58b016d173 | ||
|
|
c884571384 | ||
|
|
cfaa2b39c1 | ||
|
|
a68467150e | ||
|
|
ed095285c5 | ||
|
|
4ad437d557 | ||
|
|
666e7717f8 | ||
|
|
5f4a6c5160 | ||
|
|
36ea53f612 | ||
|
|
540475b50f | ||
|
|
1d8ffa2d8a | ||
|
|
02f5e05761 | ||
|
|
1cba90ff15 | ||
|
|
5a519540bc | ||
|
|
782e614b29 | ||
|
|
f131b2486a | ||
|
|
c399864e95 | ||
|
|
4e49a0fede | ||
|
|
00a6c8143a | ||
|
|
ab7c566270 | ||
|
|
70742d5083 | ||
|
|
75c9a4e482 | ||
|
|
ba7281d399 | ||
|
|
31aa305522 | ||
|
|
9a3ef54f53 | ||
|
|
14b58db9c6 | ||
|
|
d83ed6f774 | ||
|
|
100b2fc46e | ||
|
|
53d2f3f57b | ||
|
|
024074b2cf | ||
|
|
4436209213 | ||
|
|
c8a551a781 | ||
|
|
e0d385af38 | ||
|
|
135641d66c | ||
|
|
f63ef6ba04 | ||
|
|
b62b8639a6 | ||
|
|
253b92377d | ||
|
|
b006343740 | ||
|
|
f0133d1b1b | ||
|
|
d1722923fd | ||
|
|
242c004749 | ||
|
|
e24860f474 | ||
|
|
ecb95cc161 | ||
|
|
4e23c9104d | ||
|
|
179abe7087 | ||
|
|
2b5a224a4f | ||
|
|
c350d153da | ||
|
|
347b7e6a06 | ||
|
|
802c1b41ff | ||
|
|
7e8560f9a9 | ||
|
|
580d7761e1 | ||
|
|
149ab3ca8a | ||
|
|
b7234d339a | ||
|
|
9abba42df7 | ||
|
|
22c26dba36 | ||
|
|
7e9c08993d | ||
|
|
3f6fc215e9 | ||
|
|
62d5a7b825 | ||
|
|
2b1d703c4e | ||
|
|
b98c506baf | ||
|
|
60cf40f0b8 | ||
|
|
9c96e7c7a2 | ||
|
|
ce0d04226e | ||
|
|
eec2147826 | ||
|
|
93d7c7ed77 | ||
|
|
1a44fbee0f | ||
|
|
9cbd8937d7 | ||
|
|
ca6979d97e | ||
|
|
72ec983c4f | ||
|
|
f63c324764 | ||
|
|
ea3ba6e0d4 | ||
|
|
bf2a45f83e | ||
|
|
3f8bc43596 | ||
|
|
e6143beb25 | ||
|
|
3b0f00520e | ||
|
|
db0afaedfa | ||
|
|
a92bd780c8 | ||
|
|
04dbb0e4bb | ||
|
|
601ddee38b | ||
|
|
1e1554937c | ||
|
|
b4421a0532 | ||
|
|
7c3eeaff27 | ||
|
|
ed47d2f8b6 | ||
|
|
643e59e204 | ||
|
|
5dd48da5c8 | ||
|
|
134518ea52 | ||
|
|
a2b01b9681 | ||
|
|
bccd80882c | ||
|
|
eefb0d2df1 | ||
|
|
edfbfe8eee | ||
|
|
8510158aa0 | ||
|
|
760ed38297 | ||
|
|
95e7c5ce3b | ||
|
|
e92091c922 | ||
|
|
edf3cf93bb | ||
|
|
a110b24d76 | ||
|
|
1813100142 | ||
|
|
e29fb43754 | ||
|
|
d32fe11a19 | ||
|
|
db577eddd9 | ||
|
|
603d29f4ba | ||
|
|
ba5af175ba | ||
|
|
a9c7be6744 | ||
|
|
4ff7888bdc | ||
|
|
80e514e5d4 | ||
|
|
54b48da071 | ||
|
|
1b2f452373 | ||
|
|
4f25b011e1 | ||
|
|
6c95a4285a | ||
|
|
f2e42dd9d8 | ||
|
|
936a3958a5 | ||
|
|
eb8b76819d | ||
|
|
11bc9703c0 | ||
|
|
9a77d7f93e | ||
|
|
2f5cf8fce4 | ||
|
|
0d0360b277 | ||
|
|
7515359c3f | ||
|
|
30a89dedbd | ||
|
|
f5e1987367 | ||
|
|
45222d6b2a | ||
|
|
3513b220c0 | ||
|
|
81278afefe | ||
|
|
eaca39b557 | ||
|
|
27864e8128 | ||
|
|
ec77861fae | ||
|
|
52ea94161c | ||
|
|
ed77b3ef84 | ||
|
|
2f61c3fc81 | ||
|
|
2ffd248eb5 | ||
|
|
ed4ced1ab6 | ||
|
|
77d201f9d3 | ||
|
|
3e1e640bb3 | ||
|
|
c802bd2ce2 | ||
|
|
5c6ccbf0d3 | ||
|
|
4559608aa5 | ||
|
|
e0b6a23e4a | ||
|
|
f42c53f9e5 | ||
|
|
9563ae4c15 | ||
|
|
331a55ec89 | ||
|
|
6fec2aaf90 | ||
|
|
27ec33e007 | ||
|
|
275291e61f | ||
|
|
ee6621cc63 | ||
|
|
57007a60fc | ||
|
|
e048febffb | ||
|
|
6ad93577db | ||
|
|
12e76b3434 | ||
|
|
cb2f4e5773 | ||
|
|
e6a14dda4d | ||
|
|
8163c20342 | ||
|
|
aa6375c093 | ||
|
|
9599a2c37b | ||
|
|
f5f3927e69 | ||
|
|
696b737612 | ||
|
|
09e868eec0 | ||
|
|
6cbe5ad9b7 | ||
|
|
5976afce2e | ||
|
|
8581f477d2 | ||
|
|
7d3bc01899 | ||
|
|
bd558d6a30 | ||
|
|
5d4b234fdb | ||
|
|
149601d17c | ||
|
|
b79709f61c | ||
|
|
7922ac4da5 | ||
|
|
d55f3bdcae | ||
|
|
aee00b0ff8 | ||
|
|
a0d1825701 | ||
|
|
cc2fda0cc2 | ||
|
|
e67b0f7e24 | ||
|
|
96d0900cf7 | ||
|
|
98441355c9 | ||
|
|
2e0f7922ec | ||
|
|
df3a9e7756 | ||
|
|
5e7f359b82 | ||
|
|
4ef452bcd8 | ||
|
|
d1af2ea8c0 | ||
|
|
cda51f7277 | ||
|
|
094545dcbb | ||
|
|
d79dce64fe | ||
|
|
c1152cfe17 | ||
|
|
ea418f9dc4 | ||
|
|
5118ab8d0a | ||
|
|
e42c04d40f | ||
|
|
3618e0a976 | ||
|
|
d0aad220df | ||
|
|
98e633461f | ||
|
|
cb33018341 | ||
|
|
07c08e2817 | ||
|
|
37f01810f5 | ||
|
|
9b4dd7b1bb | ||
|
|
98414da4d5 | ||
|
|
3450ce71a6 | ||
|
|
f162081ec1 | ||
|
|
6222f7410a | ||
|
|
665067eb25 | ||
|
|
dd25180f7c | ||
|
|
ea38e8e93b | ||
|
|
ddb2da2b8f | ||
|
|
3268d99b43 | ||
|
|
a5314c992d | ||
|
|
683f31438f | ||
|
|
69e9eb0805 | ||
|
|
d18208ef6b | ||
|
|
9ec4b0aa4d | ||
|
|
10dcc4300e | ||
|
|
ce65f8dce0 | ||
|
|
ad4c4ac81b | ||
|
|
31dc8a72d4 | ||
|
|
e4daa2d727 | ||
|
|
a8d2017abc | ||
|
|
f81e089d63 | ||
|
|
acc32dc819 | ||
|
|
ca29e429e7 | ||
|
|
39afeda279 | ||
|
|
23c5f7b8c0 | ||
|
|
91c7349026 | ||
|
|
80995f5264 | ||
|
|
56c9edb547 | ||
|
|
af21691d4e | ||
|
|
3a228e3c1f | ||
|
|
d299a9009f | ||
|
|
667aeeb24d | ||
|
|
067560ae74 | ||
|
|
ef0656f162 | ||
|
|
a8a5a85c5c | ||
|
|
4dcd00089e | ||
|
|
f4caf244af | ||
|
|
a91deeb347 | ||
|
|
3804c69428 | ||
|
|
1b45d32af2 | ||
|
|
83e3b8f24f | ||
|
|
29f6fea4aa | ||
|
|
bf61350280 | ||
|
|
ecf2cdfba2 | ||
|
|
9fc2c6129b | ||
|
|
8f80f2f9cd | ||
|
|
81d81952d3 | ||
|
|
ed532cb51b | ||
|
|
a46e05258c | ||
|
|
a35dbefeda | ||
|
|
74f4149034 | ||
|
|
34cc40f459 | ||
|
|
6f5aa06fb3 | ||
|
|
b28e308bfd | ||
|
|
3d23cea071 | ||
|
|
f7b8efd964 | ||
|
|
3c7e3d7586 | ||
|
|
f359f5fb61 | ||
|
|
50deb280b5 | ||
|
|
7654a6b2ed | ||
|
|
dd9e7d6532 | ||
|
|
37ebfefea3 | ||
|
|
6d8ecbb49a | ||
|
|
dfb005ae9e | ||
|
|
5806522402 | ||
|
|
930bcce7da | ||
|
|
ad7d7638d3 | ||
|
|
da05245b4a | ||
|
|
9469aaf333 | ||
|
|
363218b0eb | ||
|
|
1de5458ad7 | ||
|
|
3c0e4a195e | ||
|
|
30866ccbae | ||
|
|
858d680371 | ||
|
|
252e9077e6 | ||
|
|
6c06413dfe | ||
|
|
a8ee0ca19b | ||
|
|
5a48cc5b42 | ||
|
|
ae9b9f9c14 | ||
|
|
874f1b999e | ||
|
|
64611e1df4 | ||
|
|
ebe1504d75 | ||
|
|
6dc4be24e1 | ||
|
|
257fa5407b | ||
|
|
b8fbe0094c | ||
|
|
9c815a6b4c | ||
|
|
2d854510e3 | ||
|
|
374c0675f1 | ||
|
|
766a65bed0 | ||
|
|
7ecd0aa574 | ||
|
|
c5280b3ebd | ||
|
|
8756937946 | ||
|
|
de94085558 | ||
|
|
7d1cbe0f70 | ||
|
|
8e189b4a4a | ||
|
|
c1866d7091 | ||
|
|
eca0370c65 | ||
|
|
ee7c28c119 | ||
|
|
1ae6274e45 | ||
|
|
0adef71f6a | ||
|
|
d4195b2908 | ||
|
|
33603ed826 | ||
|
|
1279daa2fc | ||
|
|
ab4f43c6bb | ||
|
|
e4bbeece09 | ||
|
|
997c3fbcde | ||
|
|
14c8eddcbd | ||
|
|
81d99a76fc | ||
|
|
4555bdec11 | ||
|
|
9103304399 | ||
|
|
1ab10410a8 | ||
|
|
8a16b851ad | ||
|
|
a27f2479af | ||
|
|
f50ae14f9e | ||
|
|
b02aecb45d | ||
|
|
4e716c6b74 | ||
|
|
63460a982b | ||
|
|
c6d5d41933 | ||
|
|
5544275e0d | ||
|
|
f976ede2d1 | ||
|
|
751cc62a81 | ||
|
|
77b98260e9 | ||
|
|
986acd481b | ||
|
|
f8f46c630a | ||
|
|
4df6f00ed9 | ||
|
|
6647b09cf7 | ||
|
|
f36a90afae | ||
|
|
3c3ae4c6ab | ||
|
|
4110c67db4 | ||
|
|
4ac6a7d706 | ||
|
|
1b7ef20ad1 | ||
|
|
913a9caa87 | ||
|
|
58444fb213 | ||
|
|
7917f0a5ad | ||
|
|
8d8868e5d5 | ||
|
|
a6b3b980f2 | ||
|
|
d5c331076c | ||
|
|
bb4a64c35d | ||
|
|
757f0b08ff | ||
|
|
5bb168eb6e | ||
|
|
cee3f8af78 | ||
|
|
70cc884014 | ||
|
|
e4475b5e99 | ||
|
|
2e216d6bf5 | ||
|
|
e428e7ff8e | ||
|
|
083715e097 | ||
|
|
b0bb87ba0a | ||
|
|
83cd133c66 | ||
|
|
327a21ee10 | ||
|
|
0d645cec30 | ||
|
|
82d28e143b | ||
|
|
c0b48a007c | ||
|
|
60b143fe01 | ||
|
|
be618e07a6 | ||
|
|
893da14d50 | ||
|
|
83ef709a71 | ||
|
|
5f54db2d60 | ||
|
|
33e6fdadd7 | ||
|
|
fe947248bd | ||
|
|
b7c9a3b821 | ||
|
|
fa8df65b50 | ||
|
|
26a87a16a8 | ||
|
|
66bc219b32 | ||
|
|
0ad7431528 | ||
|
|
e433eb4962 | ||
|
|
b5b9098429 | ||
|
|
49ff4e4bc0 | ||
|
|
59a7b6c42d | ||
|
|
f9ed5651e6 | ||
|
|
efb9ac21f0 | ||
|
|
a8f2aa71cc | ||
|
|
043600595f | ||
|
|
c106b75261 | ||
|
|
55336ac010 | ||
|
|
778231dc80 | ||
|
|
61d9555dc0 | ||
|
|
4b963c3ab4 | ||
|
|
2788fa4fdf | ||
|
|
1468cecfad | ||
|
|
8f75441317 | ||
|
|
007e8a372a | ||
|
|
7606abb8f3 | ||
|
|
e3192bfbe6 | ||
|
|
9d7adbec63 | ||
|
|
2d1811dcb4 | ||
|
|
cfa86a9f2a | ||
|
|
7a663e2a3c | ||
|
|
1a73a9614b | ||
|
|
660bb20bba | ||
|
|
f03dcf7193 | ||
|
|
64dbf4ff35 | ||
|
|
edd0e58031 | ||
|
|
887311827a | ||
|
|
ce98947d07 | ||
|
|
5d92341189 | ||
|
|
2a501566d7 | ||
|
|
56a1e86788 | ||
|
|
9c51d56c6a | ||
|
|
736e4e276c | ||
|
|
14486c0276 | ||
|
|
6edb7bb0c7 | ||
|
|
dbde08cc74 | ||
|
|
f61d96bf93 | ||
|
|
b032694e01 | ||
|
|
6c96afcb5a | ||
|
|
73a7338140 | ||
|
|
925b2870eb | ||
|
|
65413e50d1 | ||
|
|
a0ae357d9b | ||
|
|
e6b2cf7f55 | ||
|
|
b0bafb70e4 | ||
|
|
2fccb9dac7 | ||
|
|
7f07af1b62 | ||
|
|
02895a7d84 | ||
|
|
9713ca445c | ||
|
|
f6ef90fe14 | ||
|
|
7a87dd6805 | ||
|
|
5e0f9b3e89 | ||
|
|
c60d46d773 | ||
|
|
72527366cb | ||
|
|
de426b9833 | ||
|
|
c7923bbcff | ||
|
|
29b2bec1e7 | ||
|
|
e97c0d7288 | ||
|
|
68d88be975 | ||
|
|
cecb72f20d | ||
|
|
d7225f40cd | ||
|
|
99bf1799a6 | ||
|
|
3470b9a656 | ||
|
|
803d1b2d4a | ||
|
|
a410e81689 | ||
|
|
8b299428b3 | ||
|
|
76567d1e53 | ||
|
|
0683b0f483 | ||
|
|
b802915067 | ||
|
|
497fa3cdf3 | ||
|
|
5ddde9cee2 | ||
|
|
e946116cc8 | ||
|
|
e7fb74b73f | ||
|
|
683121ace2 | ||
|
|
a3a3b20ded | ||
|
|
ba25ff879a | ||
|
|
93f1964052 | ||
|
|
33df7fab30 | ||
|
|
65fa595602 | ||
|
|
355902fe25 | ||
|
|
19d1547606 | ||
|
|
582b73cee0 | ||
|
|
063a15c338 | ||
|
|
830195cd42 | ||
|
|
1fe47c4100 | ||
|
|
0c7dfa0ae7 | ||
|
|
0113852f7b | ||
|
|
dde7a46b87 | ||
|
|
22290294ef | ||
|
|
3f5a3683f7 | ||
|
|
dbbfd5dfcc | ||
|
|
55fa39730a | ||
|
|
610c0f7856 | ||
|
|
1505c995e3 | ||
|
|
9ba6627da8 | ||
|
|
0558e84e09 | ||
|
|
fa45185945 | ||
|
|
99265f03d1 | ||
|
|
a2fcab4045 | ||
|
|
b3b4426a46 | ||
|
|
4ff6961539 | ||
|
|
72fcee24f3 | ||
|
|
8e56b270c4 | ||
|
|
42e50889be | ||
|
|
b3a250b63f | ||
|
|
30d79fe7f7 | ||
|
|
221b1b408c | ||
|
|
1f383a3639 | ||
|
|
f3e0de4a97 | ||
|
|
48689b8191 | ||
|
|
9b99a400f9 | ||
|
|
524b631a22 | ||
|
|
0f63bb0838 | ||
|
|
acce0ec15c | ||
|
|
00b6121391 | ||
|
|
ea6e31c58b | ||
|
|
75e10b64e3 | ||
|
|
6005472fa7 | ||
|
|
d7b7b8096e | ||
|
|
3c1f1ac70a | ||
|
|
ee60c11dec | ||
|
|
65ca9af785 | ||
|
|
76a5f210a0 | ||
|
|
06d9561f37 | ||
|
|
ecc7a15a7e | ||
|
|
2ca487b936 | ||
|
|
af0848f138 | ||
|
|
a5c68c6248 | ||
|
|
6500d243eb | ||
|
|
497e5333c4 | ||
|
|
9ad58ac59c | ||
|
|
fb9f9774d7 | ||
|
|
5239eed0e8 | ||
|
|
70a961ad55 | ||
|
|
49f4e3f292 | ||
|
|
3ca283d08f | ||
|
|
08a53f54d0 | ||
|
|
11459f989e | ||
|
|
b07055a73b | ||
|
|
4618de6621 | ||
|
|
207fe5f927 | ||
|
|
fe6cba2b1b | ||
|
|
a69797d0cf | ||
|
|
d3019dbb88 | ||
|
|
7cda84b4ce | ||
|
|
a24960a7d2 | ||
|
|
028a153568 | ||
|
|
05960f8b22 | ||
|
|
610a2746f5 | ||
|
|
ab9f0be267 | ||
|
|
d3489b642a | ||
|
|
8edefc1d8f | ||
|
|
63eebc8534 | ||
|
|
6beeef9b1e | ||
|
|
ab043e5cab | ||
|
|
bba9c5e26b | ||
|
|
a6a32bbd70 | ||
|
|
9aa0fbd2dc | ||
|
|
9dd54cb781 | ||
|
|
1d8c0c9c46 | ||
|
|
be225c6fb9 | ||
|
|
3121e3ee9d | ||
|
|
0982b5d462 | ||
|
|
c31f9de905 | ||
|
|
7157d7f11d | ||
|
|
e7937d47e3 | ||
|
|
32301ba6a9 | ||
|
|
12df99084e | ||
|
|
324c0bf0fb | ||
|
|
38c25e50c2 | ||
|
|
2176c9d1af | ||
|
|
af030bf76d | ||
|
|
e376e5577c | ||
|
|
b5d4e7ddf9 | ||
|
|
3880d8fca0 | ||
|
|
df28567506 | ||
|
|
f16a9415f7 | ||
|
|
561a7f7231 | ||
|
|
d416a986bb | ||
|
|
162348ea66 | ||
|
|
7e4c4d35e4 | ||
|
|
78917e78be | ||
|
|
69e152c4fb | ||
|
|
a14e64fced | ||
|
|
e3195669fc | ||
|
|
64d60f744b | ||
|
|
85834559d1 | ||
|
|
1c66ec3ba4 | ||
|
|
99f8d0b3a6 | ||
|
|
23160e3961 | ||
|
|
2c985070e8 | ||
|
|
a14a2e6128 | ||
|
|
c093cd2322 | ||
|
|
a93bfb1e77 | ||
|
|
e1beb01a51 | ||
|
|
d20c72fe21 | ||
|
|
8d91176230 | ||
|
|
1945826414 | ||
|
|
61d08e9f71 | ||
|
|
e212054774 | ||
|
|
479c50f052 | ||
|
|
90a4d090f9 | ||
|
|
d78127ca0f | ||
|
|
5c10f1881d | ||
|
|
fa6b0f1d82 | ||
|
|
fccd37f8dd | ||
|
|
08d88a98da | ||
|
|
6e8bdb141d | ||
|
|
d152cab8c8 | ||
|
|
3dd394e3c9 | ||
|
|
2fd65ab4b0 | ||
|
|
14dd7bf290 | ||
|
|
673f4358b2 | ||
|
|
34e472a553 | ||
|
|
e07c38dc1a | ||
|
|
9e6780a248 | ||
|
|
d80c44045f | ||
|
|
b7352da5c1 | ||
|
|
2b6fbe7c58 | ||
|
|
e3173ff802 | ||
|
|
8aebf93fdf | ||
|
|
51676238c7 | ||
|
|
983c0ff52b | ||
|
|
764abddb49 | ||
|
|
df0562bba8 | ||
|
|
eaf0431b20 | ||
|
|
6394605a20 | ||
|
|
17f1d1cb99 | ||
|
|
03e34a54d4 | ||
|
|
797ee4d1a4 | ||
|
|
f775a07365 | ||
|
|
e6117e9639 | ||
|
|
9df87738ad | ||
|
|
ebfb5b3fed | ||
|
|
f125efcca3 | ||
|
|
317ba99b37 | ||
|
|
add41fdb69 | ||
|
|
457aa44832 | ||
|
|
141c79ef90 | ||
|
|
7e2b2b8f40 | ||
|
|
e68cbded97 | ||
|
|
7d5dc565f3 | ||
|
|
b3bab80342 | ||
|
|
9898309f29 | ||
|
|
55d8c6ce7d | ||
|
|
cd70a62d67 | ||
|
|
307b8bb11b | ||
|
|
fd59d2e4f8 | ||
|
|
e021735876 | ||
|
|
91debe53c4 | ||
|
|
8e0af1720a | ||
|
|
83d26a4faf | ||
|
|
0eb0855948 | ||
|
|
37e682adc7 | ||
|
|
c2f7a75cdd | ||
|
|
39232f00f1 | ||
|
|
890dd1cd5e | ||
|
|
888706149d | ||
|
|
209f457120 | ||
|
|
945d5fc2d2 | ||
|
|
a078820745 | ||
|
|
21df9d8797 | ||
|
|
cd23863226 | ||
|
|
22b10c8ac8 | ||
|
|
4b80f36fd0 | ||
|
|
026fa3d0d7 | ||
|
|
3999039102 | ||
|
|
53198e066c | ||
|
|
3318b12667 | ||
|
|
df2ab201a2 | ||
|
|
20aa3a7d65 | ||
|
|
e757591fb3 | ||
|
|
44ceaa3e71 | ||
|
|
37a7574f1f | ||
|
|
ba8cd05cb7 | ||
|
|
cdc2b3964d | ||
|
|
21b2eee7ab | ||
|
|
bc68674ce2 | ||
|
|
37b3b96e49 | ||
|
|
aeb579d6ad | ||
|
|
229bf119d4 | ||
|
|
cb7ba38f76 | ||
|
|
b80d395266 | ||
|
|
fff0959f96 | ||
|
|
b781f16add | ||
|
|
273e61bc94 | ||
|
|
9bc4f26f6e | ||
|
|
ce9778e189 | ||
|
|
44d890be59 | ||
|
|
e1e485501c | ||
|
|
a31119bd5d | ||
|
|
6b00f5c992 | ||
|
|
20bdb78084 | ||
|
|
4ac7c1213a | ||
|
|
d834742337 | ||
|
|
baf0cd7788 | ||
|
|
572309d03c | ||
|
|
d9e009864b | ||
|
|
46cc57e5fc | ||
|
|
7e2b054fc1 | ||
|
|
d358c8bc1c | ||
|
|
2bc807edc8 | ||
|
|
57364bb581 | ||
|
|
a92aebddd7 | ||
|
|
8b63b32580 | ||
|
|
76cb52eb14 | ||
|
|
48ab169c60 | ||
|
|
0f4d16400f | ||
|
|
329a0f4d7f | ||
|
|
058a67dd40 | ||
|
|
40f2a9f35a | ||
|
|
3eea703d02 | ||
|
|
74daa4d3c5 | ||
|
|
0539b25046 | ||
|
|
a7e767d0b7 | ||
|
|
78a765147e | ||
|
|
1cb5f0b3b4 | ||
|
|
a34afaa11e | ||
|
|
e8d79bdf0a | ||
|
|
e5232c6696 | ||
|
|
70fcb2cbee | ||
|
|
dab2408166 | ||
|
|
d02c734478 | ||
|
|
c4cc800040 | ||
|
|
f82b4c9bc7 | ||
|
|
1db620d2d7 | ||
|
|
3b2c5b57ad | ||
|
|
81da5af7ae | ||
|
|
69ab236d53 | ||
|
|
e7ed6ed27c | ||
|
|
5ea5003d01 | ||
|
|
7c41ef6fc9 | ||
|
|
7497e233d2 | ||
|
|
157af16d32 | ||
|
|
e0414bca05 | ||
|
|
2a6a3f36c2 | ||
|
|
337374c9e9 | ||
|
|
4946b313e1 | ||
|
|
a6505fbbb1 | ||
|
|
dd93a178fa | ||
|
|
a4fdebea2b | ||
|
|
3f63c92fd5 | ||
|
|
c8794d2b9c | ||
|
|
bf2d0b8196 | ||
|
|
e41cd6d8d2 | ||
|
|
47120dcf8c | ||
|
|
67d23dc540 | ||
|
|
99d5c50556 | ||
|
|
438df9a80b | ||
|
|
8c4a3d2b3d | ||
|
|
585c892a54 | ||
|
|
7b5f1f3884 | ||
|
|
49025dca44 | ||
|
|
2d8c37307d | ||
|
|
d294fb6d09 | ||
|
|
1649b6093b | ||
|
|
d50593a70e | ||
|
|
874cc450ba | ||
|
|
918ed66967 | ||
|
|
7fe0312359 | ||
|
|
842a79ae5d | ||
|
|
34d25cb906 | ||
|
|
b8af62d7de | ||
|
|
b28c3b7978 | ||
|
|
bf9a8400de | ||
|
|
c3c541d150 | ||
|
|
cecd13fba9 | ||
|
|
7ce7bda43e | ||
|
|
bb5161dcb0 | ||
|
|
285853e65d | ||
|
|
ab1e9ccab8 | ||
|
|
33cbdd2040 | ||
|
|
792e76b069 | ||
|
|
d572a7ca32 | ||
|
|
c4f78bb3ae | ||
|
|
77ba29c73f | ||
|
|
1a24fcb61b | ||
|
|
9dbceb4a15 | ||
|
|
c2721d1572 | ||
|
|
b7a26bb274 | ||
|
|
6ecf8f9920 | ||
|
|
c1d7a41c82 | ||
|
|
c622e43c14 | ||
|
|
119e2d5421 | ||
|
|
b574768e2b | ||
|
|
2aa3bc2018 | ||
|
|
627e012f3f | ||
|
|
4d39bf93ba | ||
|
|
d2f7830b9e | ||
|
|
30db4c7fe9 | ||
|
|
b020fc3901 | ||
|
|
3f102e0151 | ||
|
|
e18014a8a7 | ||
|
|
074f2cfdb2 | ||
|
|
91f5b36fbc | ||
|
|
9ad7798713 | ||
|
|
807999928e | ||
|
|
0b1bbf3d2b | ||
|
|
d93e639e4b | ||
|
|
b633c309f4 | ||
|
|
a00cf821c7 | ||
|
|
d13ea96f35 | ||
|
|
8e4bb575f1 | ||
|
|
ee8cdfa4b8 | ||
|
|
6f7d1447ea | ||
|
|
3e6120e0fa | ||
|
|
61565bffd7 | ||
|
|
0bac6f32ea | ||
|
|
462545bfe7 | ||
|
|
cc4ad0d4b9 | ||
|
|
458b04404e | ||
|
|
4143cfa4cf | ||
|
|
438e59a05e | ||
|
|
7385d07b9a | ||
|
|
5bea1f400e | ||
|
|
1a9701e51d | ||
|
|
23e0b82112 | ||
|
|
b4b5ef19fc | ||
|
|
4dd46c3df6 | ||
|
|
17e3a95768 | ||
|
|
3529cdaa2f | ||
|
|
556b7074ae | ||
|
|
952489eac4 | ||
|
|
8f326fb081 | ||
|
|
2925ab3d42 | ||
|
|
cdb9f9b40a | ||
|
|
def84eded9 | ||
|
|
d89e055f18 | ||
|
|
62f9330de8 | ||
|
|
374ed7ab97 | ||
|
|
c7bee46f60 | ||
|
|
e9b9782ede | ||
|
|
af00df9182 | ||
|
|
e286a428bf | ||
|
|
f2fc049f07 | ||
|
|
d8a485a5fb | ||
|
|
ed53030de2 | ||
|
|
4b88986de8 | ||
|
|
3df34b4ce0 | ||
|
|
f230fb22da | ||
|
|
2225847212 | ||
|
|
edbe7d0781 | ||
|
|
1d3438fb29 | ||
|
|
a5de77438b | ||
|
|
b841705023 | ||
|
|
72cdbdd4ad | ||
|
|
b8ef50fad5 | ||
|
|
c7d22892c1 | ||
|
|
8b3deb057f | ||
|
|
df42cf544e | ||
|
|
55a41ec0a3 | ||
|
|
4417f871e5 | ||
|
|
1c10f734bd | ||
|
|
214182b514 | ||
|
|
08942fb944 | ||
|
|
5dc724785b | ||
|
|
ce17be9ba6 | ||
|
|
badca621ba | ||
|
|
291cdd2c03 | ||
|
|
888d9879c9 | ||
|
|
39446d5e4f | ||
|
|
af8385fba8 | ||
|
|
10ff97b6c6 | ||
|
|
7e9191f3ef | ||
|
|
a67b1ecd0a | ||
|
|
4012ee7775 | ||
|
|
150ca6b50c | ||
|
|
6af84e9ad8 | ||
|
|
6bcad122cd | ||
|
|
003481410f | ||
|
|
9a1c3f7929 | ||
|
|
ef536750ea | ||
|
|
347a15a3b6 | ||
|
|
1e5b38c251 | ||
|
|
29f93fb153 | ||
|
|
b0975745df | ||
|
|
163460856a | ||
|
|
3ce9246904 | ||
|
|
1a021e02b9 | ||
|
|
f2d304ef0d | ||
|
|
cbfbca8d92 | ||
|
|
b175808a92 | ||
|
|
3e86e79133 | ||
|
|
3247e67ed4 | ||
|
|
bbc84f0c2d | ||
|
|
872d51e9b6 | ||
|
|
b41f189a4c | ||
|
|
25fb2bd59e | ||
|
|
76867b8351 | ||
|
|
43745f8c90 | ||
|
|
ed4daf06a4 | ||
|
|
14cc41c3c4 | ||
|
|
0598d921bc | ||
|
|
93dcfe9610 | ||
|
|
d98547dea3 | ||
|
|
a157d9ba13 | ||
|
|
85783148be | ||
|
|
7bd930bc76 | ||
|
|
c1fa7b420a | ||
|
|
9072bc6d70 | ||
|
|
480dbe4f4c | ||
|
|
26fad23c3a | ||
|
|
883dab7e97 | ||
|
|
d3f5643791 | ||
|
|
5299d24379 | ||
|
|
a229db96a6 | ||
|
|
092e44c62e | ||
|
|
722bce819b | ||
|
|
2d470a2a90 | ||
|
|
b6700dfa4c | ||
|
|
cfc76d0659 | ||
|
|
7fce3277a0 | ||
|
|
2219e4c82d | ||
|
|
68e841e62c | ||
|
|
bb70c36b36 | ||
|
|
c391fd6d56 | ||
|
|
e69caf5059 | ||
|
|
8b7e71049b | ||
|
|
50e190c755 | ||
|
|
d0eccf026b | ||
|
|
39f796ce22 | ||
|
|
5610e79db4 | ||
|
|
e782b78b16 | ||
|
|
c0d3969244 | ||
|
|
c62af3df33 | ||
|
|
6d736996fd | ||
|
|
8bc801d0a4 | ||
|
|
2c6b7f7fb1 | ||
|
|
c3503f56d1 | ||
|
|
d4c87996f0 | ||
|
|
9f5b3a8b1c | ||
|
|
d06e1e2a5c | ||
|
|
22a0c52af3 | ||
|
|
85aa7e89c2 | ||
|
|
59d04f2446 | ||
|
|
9cc52e30d6 | ||
|
|
e1a4e815dc | ||
|
|
3c340d1ab9 | ||
|
|
138248fafc | ||
|
|
834eefb0bb | ||
|
|
7835eb5deb | ||
|
|
d1a5c66147 | ||
|
|
b184ccfb78 | ||
|
|
4776b32cd3 | ||
|
|
2bc5333f2b | ||
|
|
a5575456e2 | ||
|
|
bdb8dc020b | ||
|
|
faaba69554 | ||
|
|
0395bba4f5 | ||
|
|
14ac7a917b | ||
|
|
7a209d4053 | ||
|
|
7e5b140c2f | ||
|
|
1f1952fb19 | ||
|
|
229bdaa308 | ||
|
|
5c0894b8c1 | ||
|
|
9cefcfb0bc | ||
|
|
5d34a5c5d5 | ||
|
|
f8c800e527 | ||
|
|
b90e4d932a | ||
|
|
5457a7e7fd | ||
|
|
8f5cc510ee | ||
|
|
0475f5e853 | ||
|
|
5b7dee0689 | ||
|
|
6532f61747 | ||
|
|
4bdae4eccb | ||
|
|
efb9840b86 | ||
|
|
308a11cb32 | ||
|
|
3a7421de33 | ||
|
|
21a58397b6 | ||
|
|
9ae61806dc | ||
|
|
87ac6f07f8 | ||
|
|
1cd5313259 | ||
|
|
04c1ff04ac | ||
|
|
0e1a0afa2c | ||
|
|
5227bb68b5 | ||
|
|
fb68941768 | ||
|
|
8747ec8d02 | ||
|
|
abd939625f | ||
|
|
69716abb25 | ||
|
|
1f526d440a | ||
|
|
84374c86e6 | ||
|
|
45ea46b105 | ||
|
|
1333d6a491 | ||
|
|
b7e865dbf1 | ||
|
|
1c411f5552 | ||
|
|
364e48a5d3 | ||
|
|
63cb89dcfc | ||
|
|
6e316b46f0 | ||
|
|
3f23396536 | ||
|
|
c628ba10f2 | ||
|
|
9358299f14 | ||
|
|
d445c4a015 | ||
|
|
e32002545b | ||
|
|
7ac88efac1 | ||
|
|
9f71fe05aa | ||
|
|
ad3c533145 | ||
|
|
e43a939f54 | ||
|
|
e5b7409f44 | ||
|
|
9100f199b1 | ||
|
|
bcc50a31a9 | ||
|
|
c891ba2bad | ||
|
|
2f9e77ca13 | ||
|
|
f346209c82 | ||
|
|
0742fb6188 | ||
|
|
94239866a5 | ||
|
|
2681b84a20 | ||
|
|
b5437c56e9 | ||
|
|
f640630a06 | ||
|
|
53e201bd28 | ||
|
|
51d962aeab | ||
|
|
5f36cf9a12 | ||
|
|
d812066f2e | ||
|
|
7563863be2 | ||
|
|
9654d487ba | ||
|
|
5b339aef3e | ||
|
|
47a7d81bb9 | ||
|
|
a92c44e53f | ||
|
|
cc9f5dd516 | ||
|
|
6e34de0e02 | ||
|
|
5a6d7f853b | ||
|
|
a646f49866 | ||
|
|
98a33b8b50 | ||
|
|
8aebaab3fe | ||
|
|
798d8c3ea3 | ||
|
|
bbaf2b0714 | ||
|
|
74a8283bba | ||
|
|
e869e55252 | ||
|
|
e8a76817dc | ||
|
|
e839c77844 | ||
|
|
ada7254b84 | ||
|
|
cd96ea7e26 | ||
|
|
0098540cc9 | ||
|
|
b3e7e2ff62 | ||
|
|
582937de8e | ||
|
|
5f5953edd8 | ||
|
|
50cd6ff955 | ||
|
|
82c53bd20b | ||
|
|
0d0f5fb182 | ||
|
|
3773c9c7fa | ||
|
|
b7dc67b9c7 | ||
|
|
76c4209a5e | ||
|
|
76d9a99758 | ||
|
|
1db858027e | ||
|
|
d3fb3710ff | ||
|
|
170cecd112 | ||
|
|
f469699449 | ||
|
|
c4ff7315c9 | ||
|
|
ddbd338b6f | ||
|
|
77c6f934dc | ||
|
|
f72bf4e4c5 | ||
|
|
dcc6bd2b62 | ||
|
|
01fac79902 | ||
|
|
70d3f54834 | ||
|
|
650dcdb35f | ||
|
|
b27e14826a | ||
|
|
d2b9333288 | ||
|
|
cbd60d02d9 | ||
|
|
93a1eade2a | ||
|
|
5073a9c506 | ||
|
|
86f8df03b6 | ||
|
|
a7ef76b9c4 | ||
|
|
0a6719cf24 | ||
|
|
0b0f68d579 | ||
|
|
c2d58ebe3a | ||
|
|
894898a75d | ||
|
|
5da1f70b6c | ||
|
|
15e90c628a | ||
|
|
bc0d1ed5e8 | ||
|
|
fa12858bd3 | ||
|
|
2f733ff1aa | ||
|
|
ee0369c553 | ||
|
|
d17f531d19 | ||
|
|
0c4400920c | ||
|
|
15b2dcb6b6 | ||
|
|
39f51a9620 | ||
|
|
632cc0e7db | ||
|
|
f5cb22da8f | ||
|
|
7f186df54d | ||
|
|
590f5cff9a | ||
|
|
e6908ee259 | ||
|
|
5b7ca9d9e6 | ||
|
|
93ac0ba5d0 | ||
|
|
5d3c1e2d4a | ||
|
|
f080f5b80a | ||
|
|
f1382b75ec | ||
|
|
d175981c71 | ||
|
|
5e42066874 | ||
|
|
52a41663eb | ||
|
|
f0183bdd8a | ||
|
|
2398805617 | ||
|
|
08168681b6 | ||
|
|
fa3874ec45 | ||
|
|
fc634380b0 | ||
|
|
6b84dd36b0 | ||
|
|
93245434c0 | ||
|
|
06913144f8 | ||
|
|
04947015aa | ||
|
|
e7ab778929 | ||
|
|
147ab2ce4c | ||
|
|
af2a025cff | ||
|
|
2da5ba80ba | ||
|
|
d4700d0cdd | ||
|
|
e2426eff08 | ||
|
|
2b16617ea3 | ||
|
|
816234f0fa | ||
|
|
d960efdc4d | ||
|
|
bd664c3a1f | ||
|
|
dc151ad1a7 | ||
|
|
2f3fb51884 | ||
|
|
29c7f3a920 | ||
|
|
36fe842bec | ||
|
|
3a8a503c8e | ||
|
|
73213d4321 | ||
|
|
7d19d3e403 | ||
|
|
c157d52c1d | ||
|
|
3034fb6b5b | ||
|
|
fee6f29cf0 | ||
|
|
a531551573 | ||
|
|
53bdee68d5 | ||
|
|
0b8cb94cc2 | ||
|
|
975656ef6f | ||
|
|
ce6622244d | ||
|
|
b649cf19ce | ||
|
|
96902ae2bd | ||
|
|
97cb2f1dfc | ||
|
|
00158b0107 | ||
|
|
146826b142 | ||
|
|
979276e0b5 | ||
|
|
0a6009b38f | ||
|
|
8656cf992e | ||
|
|
4f48e48a99 | ||
|
|
6dac01102d | ||
|
|
cd161067db | ||
|
|
a9173c076b | ||
|
|
8ffe53ea68 | ||
|
|
4d9c93734f | ||
|
|
83ff343186 | ||
|
|
71a8b2b177 | ||
|
|
c51963529d | ||
|
|
979e763739 | ||
|
|
834f2d7682 | ||
|
|
16475fe408 | ||
|
|
ec5b19acad | ||
|
|
d2e1e5be4b | ||
|
|
3603ef9c9d | ||
|
|
3aed60afe2 | ||
|
|
e1e2c2efa9 | ||
|
|
55b4e1e26d | ||
|
|
2271c086b5 | ||
|
|
cb336c9ba5 | ||
|
|
ad0a6af047 | ||
|
|
22afb8333c | ||
|
|
2b4631195a | ||
|
|
d5f0699fc3 | ||
|
|
5c84fc6213 | ||
|
|
d9f11b9f5e | ||
|
|
bb2a68e066 | ||
|
|
cd426ba6ca | ||
|
|
491bbb68a6 | ||
|
|
b3bf3e27ee | ||
|
|
523ce60093 | ||
|
|
3f00cfbfb8 | ||
|
|
2dd9edd8ca | ||
|
|
6145383a65 | ||
|
|
c0721a3f85 | ||
|
|
c10497bd03 | ||
|
|
5b1542e49b | ||
|
|
96269a7f45 | ||
|
|
bd03277bfe | ||
|
|
c072027b87 | ||
|
|
e409391f14 | ||
|
|
030228e9b8 | ||
|
|
d584d3d553 | ||
|
|
2049b35ee2 | ||
|
|
285bc6611f | ||
|
|
be8177b8a4 | ||
|
|
9c80db786e | ||
|
|
d062b4345d | ||
|
|
03bf1527cc | ||
|
|
38318262e9 | ||
|
|
eefad65904 | ||
|
|
4d6a922402 | ||
|
|
e32d6e2d5d | ||
|
|
9ea462ef7a | ||
|
|
1681e159bd | ||
|
|
3b8973fa12 | ||
|
|
ef1989f600 | ||
|
|
023e54a9a8 | ||
|
|
73b0a3d941 | ||
|
|
f86019a628 | ||
|
|
1839120e9d | ||
|
|
8e110221a3 | ||
|
|
8df7712633 | ||
|
|
149ffb899b | ||
|
|
4f60cd4e57 | ||
|
|
e83e26b6db | ||
|
|
4cd533117f | ||
|
|
20cab617c7 | ||
|
|
323cfec931 | ||
|
|
ced09b2b95 | ||
|
|
93f8c67f9f | ||
|
|
999849c62b | ||
|
|
4babc51588 | ||
|
|
44ccc167ff | ||
|
|
eae8295811 | ||
|
|
c76cb6737e | ||
|
|
af723c5370 | ||
|
|
57e4ed476c | ||
|
|
167c10fafc | ||
|
|
6d1a9f5b7c | ||
|
|
bd0bb94c52 | ||
|
|
e1a833b1a8 | ||
|
|
7bd6df1e99 | ||
|
|
d3fcf8cea2 | ||
|
|
c7eb82e4dd | ||
|
|
20d07ded7b | ||
|
|
fc57ca4a68 | ||
|
|
444c57fdfb | ||
|
|
d8b7f88dad | ||
|
|
ca61f340db | ||
|
|
601ac66762 | ||
|
|
c204110a6f | ||
|
|
e8d0eedc2b | ||
|
|
7b55b8ba86 | ||
|
|
069aa2b5be | ||
|
|
eeff03c7aa | ||
|
|
791fcea466 | ||
|
|
f56c9007bb | ||
|
|
360ba5ca95 | ||
|
|
7adf2038f1 | ||
|
|
a77744d8e6 | ||
|
|
dd47283fda | ||
|
|
5cc85e0444 | ||
|
|
6e51070590 | ||
|
|
a7853fe6d0 | ||
|
|
590dcd0b4f | ||
|
|
e25107309b | ||
|
|
def29c7668 | ||
|
|
0c92c69ed8 | ||
|
|
54ce18bb75 | ||
|
|
0ebde397fa | ||
|
|
8bf93619a0 | ||
|
|
2727c02c56 | ||
|
|
d6ac15df40 | ||
|
|
c2a6c7fa22 | ||
|
|
a742e5016e | ||
|
|
248ef0e1b4 | ||
|
|
19101fda39 | ||
|
|
9d1cfd4a22 | ||
|
|
cb20784685 | ||
|
|
66d524c096 | ||
|
|
aceef15481 | ||
|
|
d4ca3de40f | ||
|
|
f0def03d0e | ||
|
|
b2b070232d | ||
|
|
27935123cf | ||
|
|
d40c6be60d | ||
|
|
aa93eb62f2 | ||
|
|
94c32c9fd0 | ||
|
|
3b0951f6d5 | ||
|
|
4385efb0f7 | ||
|
|
d241db5c11 | ||
|
|
d9a3a5086c | ||
|
|
0c61385df4 | ||
|
|
cf142b3a91 | ||
|
|
9a503696c8 | ||
|
|
bfdfd83f2a | ||
|
|
95f8c35c36 | ||
|
|
c065af147a | ||
|
|
11ea0c8c27 | ||
|
|
dbea21fadd | ||
|
|
4d5f2ab219 | ||
|
|
b82ff327cf | ||
|
|
44b17ccc3a | ||
|
|
b2e1294452 | ||
|
|
23a10343ca | ||
|
|
5805f13a62 | ||
|
|
d39f0201f4 | ||
|
|
94cf9a209e | ||
|
|
691842c1bc | ||
|
|
eb255e7016 | ||
|
|
fe19472a2c | ||
|
|
526a1a5d33 | ||
|
|
719c993a60 | ||
|
|
70697a762c | ||
|
|
a62f5805ca | ||
|
|
87a6701464 | ||
|
|
3f3a13bff6 | ||
|
|
982906757e | ||
|
|
c1412ee755 | ||
|
|
e974a4a960 | ||
|
|
0549cdcb36 | ||
|
|
0e32dd58fa | ||
|
|
69b54a000c | ||
|
|
0d8b04ffa6 | ||
|
|
9251f44dec | ||
|
|
fde0c285d2 | ||
|
|
44467f4725 | ||
|
|
0767a2ceff | ||
|
|
9b27118a3b | ||
|
|
b98ee17e14 | ||
|
|
c046f0365c | ||
|
|
16390d3159 | ||
|
|
1b34dc0941 | ||
|
|
4a88e0bcae | ||
|
|
1e52a0b7f3 | ||
|
|
f6d0e7fea4 | ||
|
|
4af5d457eb | ||
|
|
e804326d54 | ||
|
|
5b9e9ba6bf | ||
|
|
4f25cf1366 | ||
|
|
170ac7d9e8 | ||
|
|
eb208d735b | ||
|
|
25382b01e2 | ||
|
|
d55587e341 | ||
|
|
7d9ff0599b | ||
|
|
0efd08539e | ||
|
|
291017f1a9 | ||
|
|
7549789248 | ||
|
|
5d81574226 | ||
|
|
9ccbbbd475 | ||
|
|
f6285a8e6a | ||
|
|
9f3c9e180d | ||
|
|
97bc3ba3b5 | ||
|
|
8e414a3efc | ||
|
|
a0d437357e | ||
|
|
0b0b3611bb | ||
|
|
dd22c54f32 | ||
|
|
4e153a2bc1 | ||
|
|
51d9bdb655 | ||
|
|
25374946e0 | ||
|
|
689f8a2280 | ||
|
|
36b160f934 | ||
|
|
bf965c2604 | ||
|
|
e6b9d2dcfd | ||
|
|
33afeac10d | ||
|
|
2c0b818aba | ||
|
|
c5043d66f9 | ||
|
|
1b8e88e1a2 | ||
|
|
d599a3d57b | ||
|
|
461d1ce512 | ||
|
|
8c9ce2184e | ||
|
|
e5b1d5afc8 | ||
|
|
214ed54584 | ||
|
|
97aa0aae9f | ||
|
|
92399fe537 | ||
|
|
b6aa769f12 | ||
|
|
21a38aed6e | ||
|
|
48c5f4da9d | ||
|
|
7b46b1a89b | ||
|
|
85adb811bb | ||
|
|
79dc868e6e | ||
|
|
52cd458e76 | ||
|
|
59c523c575 | ||
|
|
e0a0036aa0 | ||
|
|
4d3640caaa | ||
|
|
f4ab972e3a | ||
|
|
e698cd9a4a | ||
|
|
99f4e174ad | ||
|
|
476fe84570 | ||
|
|
6ac68029e4 | ||
|
|
d02fe9d8df | ||
|
|
4d3e08fe38 | ||
|
|
e8ecdd0fac | ||
|
|
bc04d5ecb9 | ||
|
|
da71f225ca | ||
|
|
5439a12fe8 | ||
|
|
ca67ee41c5 | ||
|
|
a29139dccb | ||
|
|
ca30732f31 | ||
|
|
8f1b6bb402 | ||
|
|
b5a7c08fde | ||
|
|
8a54b391f3 | ||
|
|
7911ffa835 | ||
|
|
48532231c9 | ||
|
|
9e3787b0a3 | ||
|
|
32005942e4 | ||
|
|
a00a42b244 | ||
|
|
288dd99f44 | ||
|
|
ed981de47a | ||
|
|
3b345f8525 | ||
|
|
6d9aa9b676 | ||
|
|
ad8aa4a4a2 | ||
|
|
1fe9fda31e | ||
|
|
dd3dfff172 | ||
|
|
336a3d5c81 | ||
|
|
c0af840fc1 | ||
|
|
4484d7f377 | ||
|
|
12b135a3db | ||
|
|
97e83e6fc5 | ||
|
|
891893c0e5 | ||
|
|
e15a1cb972 | ||
|
|
d79adf24ba | ||
|
|
5998d66dc8 | ||
|
|
63e937314b | ||
|
|
769a02829a | ||
|
|
513ff0b81e | ||
|
|
47d2b3a1f1 | ||
|
|
0d37a32d5c | ||
|
|
d5962681f1 | ||
|
|
662b679fdc | ||
|
|
8d92e0f8c9 | ||
|
|
13dea5090a | ||
|
|
ca14d29a62 | ||
|
|
b544384225 | ||
|
|
0281b8f854 | ||
|
|
9d4330b754 | ||
|
|
b142dd45d5 | ||
|
|
f65e6b2ac5 | ||
|
|
b0d93dadc0 | ||
|
|
6a69f3920f | ||
|
|
725151cdc5 | ||
|
|
f7027d3bbc | ||
|
|
2472fe7951 | ||
|
|
3432fe8822 | ||
|
|
bcb32c3e74 | ||
|
|
67c835c133 | ||
|
|
93077c1f45 | ||
|
|
1f690dd5c8 | ||
|
|
9b6b19bf73 | ||
|
|
807fa7624e | ||
|
|
fb21a1e257 | ||
|
|
6d115df490 | ||
|
|
5af8996e66 | ||
|
|
21403cedb2 | ||
|
|
32d50a0185 | ||
|
|
cd63ad38fc | ||
|
|
ce16512905 | ||
|
|
21ecc5de54 | ||
|
|
611394b76a | ||
|
|
171d4d4ae7 | ||
|
|
05fb150ad3 | ||
|
|
37490e7d44 | ||
|
|
d1c75888cd | ||
|
|
79dfbafc13 | ||
|
|
4c3c078fa4 | ||
|
|
c95ea4440e | ||
|
|
1f0bd36c92 | ||
|
|
b171fc8fef | ||
|
|
df1a8df463 | ||
|
|
322c083531 | ||
|
|
e017135963 | ||
|
|
e87c975a24 | ||
|
|
d03b348072 | ||
|
|
18135d1bcf | ||
|
|
cb37d34a52 | ||
|
|
ddb842ecd7 | ||
|
|
2e6122025d | ||
|
|
535dc1314e | ||
|
|
6b81146286 | ||
|
|
972d6a2dc8 | ||
|
|
d092349cd8 | ||
|
|
10a92791b8 | ||
|
|
c4e23fdaf5 | ||
|
|
08ec3715b9 | ||
|
|
9968981fd0 | ||
|
|
07e8eb1adf | ||
|
|
4a03ebdb37 | ||
|
|
a6e4a67aec | ||
|
|
d2730018a8 | ||
|
|
7f0bfb6753 | ||
|
|
807ae04533 | ||
|
|
8d18b982da | ||
|
|
7e8bde717c | ||
|
|
3a468cbc50 | ||
|
|
c508929668 | ||
|
|
b07600b6ba | ||
|
|
964af4c94f | ||
|
|
c39009b5ee | ||
|
|
912c7a865e | ||
|
|
dadf3d886b | ||
|
|
5424726145 | ||
|
|
55631c6a21 | ||
|
|
7f49a0699c | ||
|
|
40d744f81f | ||
|
|
ac4d271961 | ||
|
|
53fe7a60f3 | ||
|
|
68f00df56d | ||
|
|
e23065315f | ||
|
|
d9d95e76dc | ||
|
|
2208441e86 | ||
|
|
196f551a1f | ||
|
|
2cc15070e8 | ||
|
|
0480bf19cf | ||
|
|
bf9361b26b | ||
|
|
df26984135 | ||
|
|
84edfeee28 | ||
|
|
149f84f64a | ||
|
|
475596b7b4 | ||
|
|
be1fb0836f | ||
|
|
711bf1c877 | ||
|
|
faa9db9394 | ||
|
|
9bae200836 | ||
|
|
f82bd94d8c | ||
|
|
fdb5465e34 | ||
|
|
3bc8afcc87 | ||
|
|
6e031f6e2e | ||
|
|
1c993d454a | ||
|
|
6de8d63913 | ||
|
|
f5806a1589 | ||
|
|
e41f1b7bb5 | ||
|
|
6c55035ddf | ||
|
|
b0d4458122 | ||
|
|
90a1f814c1 | ||
|
|
3fd8c79898 | ||
|
|
3ac788374b | ||
|
|
aa1acc9bf8 | ||
|
|
479b627451 | ||
|
|
ed117bdc88 | ||
|
|
4bd371a36b | ||
|
|
a4278f2e9e | ||
|
|
90b0eb8729 | ||
|
|
2625f6b6fc | ||
|
|
7b9e1af155 | ||
|
|
74d7733138 | ||
|
|
5a1fd00c04 | ||
|
|
47d9c4008d | ||
|
|
24677d81be | ||
|
|
a6dcb90d36 | ||
|
|
440248fd47 | ||
|
|
bcd1cb8866 | ||
|
|
6ad45ab0de | ||
|
|
6bce5a567e | ||
|
|
e4686cc50c | ||
|
|
6d70dd92fb | ||
|
|
fc28738edc | ||
|
|
72039fe414 | ||
|
|
844b26d2e5 | ||
|
|
7905429ea0 | ||
|
|
d265f1323d | ||
|
|
f3d4c9adb5 | ||
|
|
0e7db1eb61 | ||
|
|
04acb4102a | ||
|
|
cea11393db | ||
|
|
1db11ca924 | ||
|
|
c834ff216a | ||
|
|
32228eb89c | ||
|
|
120d180609 | ||
|
|
ccdd2091c1 | ||
|
|
eb33aeb63a | ||
|
|
28bee54bbb | ||
|
|
f160def46f | ||
|
|
2077852173 | ||
|
|
7bfedd9ed0 | ||
|
|
3ab531aeb8 | ||
|
|
16aab25ccf | ||
|
|
3082f39ef4 | ||
|
|
2caeab542c | ||
|
|
14d2d25894 | ||
|
|
c08692eae9 | ||
|
|
9f12c1d28f | ||
|
|
2384f4ef1a | ||
|
|
4413101e2a | ||
|
|
d43fbc0c18 | ||
|
|
cfb146242d | ||
|
|
82f7ebe3df | ||
|
|
39c4cfc563 | ||
|
|
524b368bf6 | ||
|
|
cab5c72f3d | ||
|
|
cd37599444 | ||
|
|
dd531b56b8 | ||
|
|
017704172b | ||
|
|
f466f16a4d | ||
|
|
a6a812e03f | ||
|
|
abee120b4e | ||
|
|
68134d3ef2 | ||
|
|
756f538a70 | ||
|
|
ddb3169c28 | ||
|
|
522a7a8378 | ||
|
|
3582fcedc5 | ||
|
|
c1083ce5b2 | ||
|
|
6e083f4cb6 | ||
|
|
145ae8baa1 | ||
|
|
366293906e | ||
|
|
cc07f1745b | ||
|
|
db9f1fe35c | ||
|
|
7057bfcf05 | ||
|
|
76ce394f7e | ||
|
|
5841cbc18e | ||
|
|
f8e0fb3a6f | ||
|
|
5611608f91 | ||
|
|
2c633d2d13 | ||
|
|
fc2a6929bc | ||
|
|
f27c346565 | ||
|
|
72e7e0e478 | ||
|
|
e8752f9ddc | ||
|
|
9873c1a366 | ||
|
|
5d3839a864 | ||
|
|
6c82fd1f0c | ||
|
|
097777c043 | ||
|
|
333fc6c0f5 | ||
|
|
d6783e5a6e | ||
|
|
5942c2c561 | ||
|
|
25c752a2de | ||
|
|
d6f9a727b8 | ||
|
|
aaae6c5446 | ||
|
|
cb30cc37cd | ||
|
|
1c7c21cdf8 | ||
|
|
14b005d64e | ||
|
|
ed08e5a9bd | ||
|
|
a7a0168655 | ||
|
|
443c1cf233 | ||
|
|
217be93785 | ||
|
|
f2664d31b0 | ||
|
|
5c44fcd88e | ||
|
|
62e2f41100 | ||
|
|
5b501eb956 | ||
|
|
ceeb213756 | ||
|
|
64bd0c7965 | ||
|
|
b117fe4e18 | ||
|
|
6d53c4534a | ||
|
|
6d1b61c7a3 | ||
|
|
d58d7146ba | ||
|
|
61aae6b47a | ||
|
|
37cb6d7d19 | ||
|
|
42b9f18f65 | ||
|
|
7e17598fd9 | ||
|
|
63d9867705 | ||
|
|
851646f7fa | ||
|
|
615454a5bc | ||
|
|
4ff893467d | ||
|
|
d8d5fbd621 | ||
|
|
517d7ec897 | ||
|
|
c6207155f6 | ||
|
|
cb82e3ef27 | ||
|
|
d5c001aad7 | ||
|
|
964d2e639b | ||
|
|
219c7d12e2 | ||
|
|
4f9a63349c | ||
|
|
2cd0486837 | ||
|
|
e4ce57b9d5 | ||
|
|
e1cb974e76 | ||
|
|
72eddcf699 | ||
|
|
76c2bef1a1 | ||
|
|
feaf747b25 | ||
|
|
74dc98b140 | ||
|
|
4f941de39c | ||
|
|
7e9010ed04 | ||
|
|
66fa6d9944 | ||
|
|
afb2711120 | ||
|
|
9b9b3b4210 | ||
|
|
a9aa50d128 | ||
|
|
cbe8ec2aff | ||
|
|
9b7a530ee9 | ||
|
|
3d278042d6 | ||
|
|
87579e5b65 | ||
|
|
a13ec71c7a | ||
|
|
727847fd83 | ||
|
|
23eaab4f35 | ||
|
|
f4595f9c08 | ||
|
|
3227f6a6bc | ||
|
|
fa5616a17f | ||
|
|
6aa216e040 | ||
|
|
17e36df0a0 | ||
|
|
43914c45c1 | ||
|
|
9a3193012c | ||
|
|
67279fbe17 | ||
|
|
3a8ae3cfae | ||
|
|
a1a2ff05b9 | ||
|
|
b26614c468 | ||
|
|
7503e2a868 | ||
|
|
488d56e699 | ||
|
|
1a44d170c3 | ||
|
|
2e72b206d7 | ||
|
|
80ee13e0f4 | ||
|
|
44e666d053 | ||
|
|
0ef6694526 | ||
|
|
9f2a59fea8 | ||
|
|
8b9be05bea | ||
|
|
bfe03a5f5e | ||
|
|
206ed87210 | ||
|
|
052800ae0e | ||
|
|
3c22269bf5 | ||
|
|
7b9051f08c | ||
|
|
ac2f10996a | ||
|
|
a4ef0fbaa9 | ||
|
|
b5c9c70822 | ||
|
|
51bcfbe767 | ||
|
|
246c87f46a | ||
|
|
44a5ef3fd6 | ||
|
|
196d51d143 | ||
|
|
4f495d1b1c | ||
|
|
68ed12541a | ||
|
|
db4e31793e | ||
|
|
de5f2b1308 | ||
|
|
acd1b52893 | ||
|
|
7dce259068 | ||
|
|
86f14cf744 | ||
|
|
da882d26a5 | ||
|
|
e92613c747 | ||
|
|
65c5f973e4 | ||
|
|
5cc6f7fcd0 | ||
|
|
450b3aff88 | ||
|
|
5e12bc3199 | ||
|
|
d6a348d110 | ||
|
|
150a02358e | ||
|
|
fc3b7f43ce | ||
|
|
e544e21f04 | ||
|
|
2809ba5b6d | ||
|
|
e2d586ca3c | ||
|
|
2a754c8fc6 | ||
|
|
7fafb5cc4b | ||
|
|
637174373f | ||
|
|
aa29fe79f6 | ||
|
|
88670cc3eb | ||
|
|
6a796a2f8d | ||
|
|
5e0f2f89c1 | ||
|
|
1a78927854 | ||
|
|
92eb635700 | ||
|
|
073a698a6a | ||
|
|
8e17067104 | ||
|
|
1d0a42215c | ||
|
|
deca27006e | ||
|
|
d3fd46451f | ||
|
|
0710dd563f | ||
|
|
57380905f6 | ||
|
|
93cb50b244 | ||
|
|
d32beb4a9f | ||
|
|
a0bf6659f1 | ||
|
|
600aa2b2fb | ||
|
|
182e60e700 | ||
|
|
370199e17b | ||
|
|
20838c2f89 | ||
|
|
7fcd36f11c | ||
|
|
314bf15395 | ||
|
|
e9febecab1 | ||
|
|
f6f520591e | ||
|
|
8b7f126263 | ||
|
|
b33e7db70f | ||
|
|
11449b0832 | ||
|
|
b234881503 | ||
|
|
cdb0f5be29 | ||
|
|
17ed17be08 | ||
|
|
c3fe71112e | ||
|
|
a5b9cd4630 | ||
|
|
dda7a3e183 | ||
|
|
2e570b368c | ||
|
|
28bacbee41 | ||
|
|
484ef274e9 | ||
|
|
436c9d0db2 | ||
|
|
3c710f3094 | ||
|
|
4e087fc608 | ||
|
|
6739422b9a | ||
|
|
e4f638a17a | ||
|
|
4df77e3fac | ||
|
|
3349f68213 | ||
|
|
7587f1fbba | ||
|
|
cc0f2ce3b2 | ||
|
|
eab1eef242 | ||
|
|
9fd81e03e9 | ||
|
|
5852349e15 | ||
|
|
8655a7b0d8 | ||
|
|
25306df2cd | ||
|
|
31ec81bb19 | ||
|
|
9d96f5c4de | ||
|
|
78af325b22 | ||
|
|
1bcf3ef77e | ||
|
|
a3522d4eaa | ||
|
|
c75f719923 | ||
|
|
09e5df5ad6 | ||
|
|
ff55b0d8f0 | ||
|
|
6c98f67413 | ||
|
|
29878ceefb | ||
|
|
1de6f8f8ab | ||
|
|
12d4204465 | ||
|
|
e60bf088c9 | ||
|
|
995d0a8c1c | ||
|
|
036dad095c | ||
|
|
111aa66405 | ||
|
|
24d0a22d35 | ||
|
|
3fa576a94e | ||
|
|
c30f107c68 | ||
|
|
f126b9ff63 | ||
|
|
7d707b4b88 | ||
|
|
222f4c5831 | ||
|
|
10724379c4 | ||
|
|
9da722d5e2 | ||
|
|
39185fa8b3 | ||
|
|
f89d609de2 | ||
|
|
f48a7e3974 | ||
|
|
b28e2094cb | ||
|
|
a200192f42 | ||
|
|
40e94ebd99 | ||
|
|
44b5f16793 | ||
|
|
91c7c1dbba | ||
|
|
9b9f9ded08 | ||
|
|
d755be8a41 | ||
|
|
90fac52c16 | ||
|
|
e9ef9e0c93 | ||
|
|
830100cd84 | ||
|
|
1726744650 | ||
|
|
1603556577 | ||
|
|
2bd6158b36 | ||
|
|
fe8425deef | ||
|
|
0ebfebe8d1 | ||
|
|
e79770dcea | ||
|
|
d4a542150b | ||
|
|
88e7b7b7ae | ||
|
|
3593a7fabd | ||
|
|
7416f5f79e | ||
|
|
3e8fe0c64c | ||
|
|
f74f0fa64c | ||
|
|
6152d58a69 | ||
|
|
a663278f05 | ||
|
|
7696c01670 | ||
|
|
8c38429439 | ||
|
|
6c9a1db8b8 | ||
|
|
d22fd28d1d | ||
|
|
d1779989ed | ||
|
|
d531a0e4c3 | ||
|
|
8fb07c725b | ||
|
|
b876889c7e | ||
|
|
1e1ad94b6d | ||
|
|
4d208094e7 | ||
|
|
ef71aa7460 | ||
|
|
06a379c281 | ||
|
|
86e55f7968 | ||
|
|
e463959fee | ||
|
|
226c24d666 | ||
|
|
8e4ea799af | ||
|
|
c7e4978d44 | ||
|
|
b9d1cb12fe | ||
|
|
ef6b9acbb4 | ||
|
|
415ccc313f | ||
|
|
31b09f4ab9 | ||
|
|
b8a0515791 | ||
|
|
b00d25b0ab | ||
|
|
53d4f657af | ||
|
|
3e0771acf3 | ||
|
|
ea10810934 | ||
|
|
8173414bf5 | ||
|
|
a919292386 | ||
|
|
83529a7f76 | ||
|
|
0c4f82c881 | ||
|
|
9aef5b0977 | ||
|
|
8981a255a7 | ||
|
|
99358a7aaf | ||
|
|
242dc59471 | ||
|
|
a473322a98 | ||
|
|
099a9331bf | ||
|
|
9a77dd28f9 | ||
|
|
4baa629894 | ||
|
|
74edbb7934 | ||
|
|
16afe4b778 | ||
|
|
fc98d8e953 | ||
|
|
be34e9d396 | ||
|
|
9fee763265 | ||
|
|
7c789ba2a5 | ||
|
|
fb3dcccc01 | ||
|
|
12fea8a1d0 | ||
|
|
ab3abb7936 | ||
|
|
c4a0548e76 | ||
|
|
b71d9655be | ||
|
|
ff6d854298 | ||
|
|
a72802470a | ||
|
|
0b92e41935 | ||
|
|
1dea4a28dc | ||
|
|
518ddd9f46 | ||
|
|
b912761fcc | ||
|
|
63da5a821a | ||
|
|
588fdb34eb | ||
|
|
4cbe3212a5 | ||
|
|
e18c2bb4fc | ||
|
|
41061179b5 | ||
|
|
ca55193d23 | ||
|
|
1945c0f52d | ||
|
|
ccda402b9b | ||
|
|
9d2e465356 | ||
|
|
7236aec3fe | ||
|
|
75d2cc4dfe | ||
|
|
63a31593b4 | ||
|
|
5903ed606b | ||
|
|
aa05f2c2bb | ||
|
|
18bca83deb | ||
|
|
b47afe8bfb | ||
|
|
db800480bf | ||
|
|
4edc408893 | ||
|
|
9cf9893ed4 | ||
|
|
bc2e7a89cc | ||
|
|
fdae83e0a2 | ||
|
|
65db7a3b15 | ||
|
|
db659da876 | ||
|
|
82a8792153 | ||
|
|
0053a840b7 | ||
|
|
106bea2a40 | ||
|
|
33ef02cfc0 | ||
|
|
9cd6f9872a | ||
|
|
12d1ce4000 | ||
|
|
d4e7cb8d5f | ||
|
|
953dd70052 | ||
|
|
e17fee85e9 | ||
|
|
6a46f8b74c | ||
|
|
a1a25465da | ||
|
|
78b668687d | ||
|
|
c9a62b6b08 | ||
|
|
9da58082a7 | ||
|
|
f20addf39d | ||
|
|
c0e411dab2 | ||
|
|
0d6c792282 | ||
|
|
09c2af28c9 | ||
|
|
50abfd7e39 | ||
|
|
8e7e9039f9 | ||
|
|
d97cf675de | ||
|
|
4791d5f040 | ||
|
|
e565011a1c | ||
|
|
22b651917b | ||
|
|
d21318b753 | ||
|
|
01272308b4 | ||
|
|
f6ecaa7cb5 | ||
|
|
38531bc983 | ||
|
|
36ba566c95 | ||
|
|
b41f865c1d | ||
|
|
08b8a17d30 | ||
|
|
74d25aa2df | ||
|
|
33d2f59055 | ||
|
|
9f328f84a5 | ||
|
|
0d26818e81 | ||
|
|
7ceaa06800 | ||
|
|
bec1c46d21 | ||
|
|
c4ddfe4a2e | ||
|
|
2ac9f33be7 | ||
|
|
8c1a9763e6 | ||
|
|
7956074746 | ||
|
|
5a3a249af5 | ||
|
|
4cc21948bc | ||
|
|
f6435291f5 | ||
|
|
166bfe5abd | ||
|
|
c43283b3ec | ||
|
|
b68fcc71dd | ||
|
|
b91ad2aba0 | ||
|
|
f67e5bc023 | ||
|
|
6e6e3d2059 | ||
|
|
c35ddcfc1f | ||
|
|
443b67024a | ||
|
|
40810aa896 | ||
|
|
8a7bc97fea | ||
|
|
8945580ff5 | ||
|
|
d8b7dc4693 | ||
|
|
8fa14863f8 | ||
|
|
dec4d83b51 | ||
|
|
7e2bad5643 | ||
|
|
fe14a4b2a8 | ||
|
|
c6164ae2ab | ||
|
|
9e05028c05 | ||
|
|
c2bd5aa5ac | ||
|
|
c3c3782f27 | ||
|
|
25fb106c8a | ||
|
|
5c9fc2f61f | ||
|
|
63ca119e92 | ||
|
|
886621397e | ||
|
|
bccbec90e7 | ||
|
|
0f2d68e492 | ||
|
|
2d12da4903 | ||
|
|
b6d5516e84 | ||
|
|
6ba1a95767 | ||
|
|
75c468d897 | ||
|
|
d282d13d35 | ||
|
|
bbb986c48f | ||
|
|
d3d59d6922 | ||
|
|
1101384705 | ||
|
|
705e1944c9 | ||
|
|
83d6be39d6 | ||
|
|
3f8cc830f7 | ||
|
|
06ac451aa6 | ||
|
|
6a0837e908 | ||
|
|
10259b5fd2 | ||
|
|
ac3a4be7b0 | ||
|
|
2308f35e66 | ||
|
|
fd3e957f33 | ||
|
|
e9ae0a8e6d | ||
|
|
10d875ffbb | ||
|
|
48bfaaa50e | ||
|
|
6e8f62df24 | ||
|
|
8483e747ff | ||
|
|
76eb6cff48 | ||
|
|
8ea441fe4b | ||
|
|
47d2ff82a9 | ||
|
|
e21fa6477e | ||
|
|
4c65e244f5 | ||
|
|
99a91c4987 | ||
|
|
0d7a2c3c20 | ||
|
|
a3a60fca98 | ||
|
|
6322574a96 | ||
|
|
cd77c037de | ||
|
|
80439d1ec0 | ||
|
|
c12316f5b4 | ||
|
|
06b9f2b882 | ||
|
|
e7022d434d | ||
|
|
9f17ba102b | ||
|
|
f483edfeaa | ||
|
|
9d229e3f31 | ||
|
|
6773924a3a | ||
|
|
0e3cdaa15d | ||
|
|
8d0282f24e | ||
|
|
2310597ada | ||
|
|
725c447cef | ||
|
|
2987c4950e | ||
|
|
e4cdc3d167 | ||
|
|
430bbd2ccf | ||
|
|
92374ab879 | ||
|
|
07f6a8889b | ||
|
|
49de66fb85 | ||
|
|
2a03295c41 | ||
|
|
506ecfe3e2 | ||
|
|
fa3e1c139a | ||
|
|
e72886cfaf | ||
|
|
04ffc17466 | ||
|
|
1ec37bb983 | ||
|
|
adf82645e3 | ||
|
|
f18bd9fb0a | ||
|
|
f237a4cafa | ||
|
|
1b185bd7f9 | ||
|
|
ce1b43fb0c | ||
|
|
50d449e0e3 | ||
|
|
fca73867fa | ||
|
|
59de9a01a9 | ||
|
|
9bd2dda749 | ||
|
|
e9947c0a68 | ||
|
|
4c52a0dc41 | ||
|
|
4a9fcbc4af | ||
|
|
ae9105bd5b | ||
|
|
60ec6c87c2 | ||
|
|
4ecbb98b17 | ||
|
|
0de99d2436 | ||
|
|
32c1071265 | ||
|
|
822f433005 | ||
|
|
7ee5a68880 | ||
|
|
83e102a043 | ||
|
|
af2639ef42 | ||
|
|
a2c2ed0aef | ||
|
|
5463ae21f8 | ||
|
|
890119db3c | ||
|
|
a6ebdca958 | ||
|
|
8d445533e7 | ||
|
|
dc302afece | ||
|
|
eb946d468c | ||
|
|
5b8bfd26cd | ||
|
|
a4d76603c1 | ||
|
|
dae73fafae | ||
|
|
eaa4ceaa38 | ||
|
|
5f5737fcfe | ||
|
|
99ecb0b22b | ||
|
|
edf960805e | ||
|
|
f2c3e51ef4 | ||
|
|
7c67fc18c8 | ||
|
|
608dc61e24 | ||
|
|
8c5c4c9840 | ||
|
|
9e29236a0c | ||
|
|
0524e02ac4 | ||
|
|
011a8a83d6 | ||
|
|
86fceb962b | ||
|
|
708f6d36d6 | ||
|
|
366ad2a9ef | ||
|
|
681077bd81 | ||
|
|
8ac46112f0 | ||
|
|
f147e902a4 | ||
|
|
fa6709f8bb | ||
|
|
ef82f9ef71 | ||
|
|
e415afa5d0 | ||
|
|
cc970afc30 | ||
|
|
07ed3f976e | ||
|
|
ebaef4c6e3 | ||
|
|
3297906fd5 | ||
|
|
e84ab3c6bc | ||
|
|
995f144166 | ||
|
|
e3fa34e524 | ||
|
|
4327d0a0f1 | ||
|
|
f40a1c963d | ||
|
|
fd5dd15506 | ||
|
|
ad1b2423e1 | ||
|
|
17cfce2a12 | ||
|
|
2e62948309 | ||
|
|
bf313e7c43 | ||
|
|
681432ff4d | ||
|
|
7d4f01e9af | ||
|
|
ff080fe6ac | ||
|
|
f9662479b4 | ||
|
|
d7e5a445a9 | ||
|
|
65d2445237 | ||
|
|
bdbe5df54e | ||
|
|
f3437487e5 | ||
|
|
5707815f2a | ||
|
|
9022962734 | ||
|
|
6ee684029e | ||
|
|
5623155624 | ||
|
|
434c5c69e9 | ||
|
|
90bc8c9ef5 | ||
|
|
7675ec79e4 | ||
|
|
42db238cdb | ||
|
|
f92ff496b0 | ||
|
|
7b8bab4cd3 | ||
|
|
5b31f676f9 | ||
|
|
63cb45980c | ||
|
|
e2c530adfb | ||
|
|
9d87f0bbd3 | ||
|
|
9faec8c56a | ||
|
|
8eb216c1de | ||
|
|
0ac5e4e239 | ||
|
|
28af890329 | ||
|
|
33bc0cca26 | ||
|
|
03635f32af | ||
|
|
9d1de187e4 | ||
|
|
3c35c6c64d | ||
|
|
2c500ffb14 | ||
|
|
c1e9f783c3 | ||
|
|
f078b98c5d | ||
|
|
dba255d118 | ||
|
|
427c762eec | ||
|
|
3be07568a5 | ||
|
|
69b2293201 | ||
|
|
872bf11ac9 | ||
|
|
b1b3a8ab84 | ||
|
|
9112938369 | ||
|
|
87d95f1ce8 | ||
|
|
d79de72f1b | ||
|
|
2eff2f6888 | ||
|
|
f2579353ab | ||
|
|
0074e4c6cc | ||
|
|
a2ab4dbc06 | ||
|
|
2d1aab4a62 | ||
|
|
6a574bfa4f | ||
|
|
12b3bf0d01 | ||
|
|
e0152f84b5 | ||
|
|
474a00f9e8 | ||
|
|
e2d3a41dcb | ||
|
|
05d76a70d9 | ||
|
|
892aee68e4 | ||
|
|
ad05186769 | ||
|
|
0c8c1436ae | ||
|
|
25111deacb | ||
|
|
964483a031 | ||
|
|
b8982cddd0 | ||
|
|
4f0569e985 | ||
|
|
e4e3580535 | ||
|
|
f69c9722c6 | ||
|
|
6a7d38b083 | ||
|
|
ea123856f4 | ||
|
|
87f0c0838b | ||
|
|
695fbcdb07 | ||
|
|
5919a796a7 | ||
|
|
a5e5c500cf | ||
|
|
18f9be2c61 | ||
|
|
78cd69e34d | ||
|
|
f482801b94 | ||
|
|
754f02f9bb | ||
|
|
b4713fa3ff | ||
|
|
b18dd28caf | ||
|
|
ebedc88bfa | ||
|
|
5fc1da5209 | ||
|
|
fc748fcb19 | ||
|
|
ab26f089bf | ||
|
|
b6555a0022 | ||
|
|
c6026f1aa6 | ||
|
|
339c6620a2 | ||
|
|
a67d0d9da2 | ||
|
|
8a46395bcb | ||
|
|
10b320c6c0 | ||
|
|
ee2d8d31f4 | ||
|
|
a5a590cc4a | ||
|
|
fbfd1e6cb9 | ||
|
|
7c23f8c431 | ||
|
|
7a70d6a51e | ||
|
|
8ef4456323 | ||
|
|
cc5fa3c859 | ||
|
|
a36eff096b | ||
|
|
e1145f58aa | ||
|
|
26194e7e21 | ||
|
|
0c1877449d | ||
|
|
c766c8bc60 | ||
|
|
34238b12eb | ||
|
|
9ee7737c34 | ||
|
|
e9b9092e7d | ||
|
|
f0459f9a8d | ||
|
|
08f40d88df | ||
|
|
3e0ae01acf | ||
|
|
717ce95500 | ||
|
|
8fde665936 | ||
|
|
e8ae14d5e4 | ||
|
|
736ca494e6 | ||
|
|
9857dda5b5 | ||
|
|
b3ec557ab9 | ||
|
|
bae82e20fe | ||
|
|
e5860f90c5 | ||
|
|
78889a04b4 | ||
|
|
2227e2a32a | ||
|
|
66605777f2 | ||
|
|
cbb963b1ea | ||
|
|
15563adbb2 | ||
|
|
ff31cce0ab | ||
|
|
0bf6caa437 | ||
|
|
dc0b436e19 | ||
|
|
5bdfcd0769 | ||
|
|
bc5f7c2b0f | ||
|
|
42b09856fd | ||
|
|
d6fa3621e8 | ||
|
|
534fb67dc5 | ||
|
|
b923f51271 | ||
|
|
55e8cb4a55 | ||
|
|
506a2a1032 | ||
|
|
3a020341cb | ||
|
|
b015cecb2a | ||
|
|
a3a03f2851 | ||
|
|
4359d1ddef | ||
|
|
1c0bdfab69 | ||
|
|
cc7d024604 | ||
|
|
bd91cb1873 | ||
|
|
c7b94163ee | ||
|
|
65202c9460 | ||
|
|
88b6c7c477 | ||
|
|
1b832b82f7 | ||
|
|
cc102eab0f | ||
|
|
3eac8d164c | ||
|
|
8399114748 | ||
|
|
1b0d5c3670 | ||
|
|
180b7fddec | ||
|
|
2eedec1a39 | ||
|
|
78c11124e2 | ||
|
|
ea0938a699 | ||
|
|
79ddc8d44d | ||
|
|
c57de18593 | ||
|
|
24b4492abc | ||
|
|
d331fcbdef | ||
|
|
0cfb30459a | ||
|
|
909d15aa5d | ||
|
|
3a4819c5b8 | ||
|
|
5e8e5424dc | ||
|
|
5c565f8c3e | ||
|
|
2cb863a163 | ||
|
|
844aee7350 | ||
|
|
df22e1b205 | ||
|
|
e8945d4de3 | ||
|
|
054970f642 | ||
|
|
3f46921c6c | ||
|
|
64e8803ec4 | ||
|
|
1bf4065b6a | ||
|
|
c0410624b5 | ||
|
|
0a7eed3276 | ||
|
|
cfe9548b25 | ||
|
|
e9219e89f3 | ||
|
|
6afc56a7ca | ||
|
|
e861611611 | ||
|
|
74d357ed4b | ||
|
|
67300cfe47 | ||
|
|
ae76ba82e1 | ||
|
|
cd56294d44 | ||
|
|
b474445c52 | ||
|
|
58740a74c3 | ||
|
|
2dec8dacc9 | ||
|
|
c4cdaca038 | ||
|
|
6f00dd56c4 | ||
|
|
9aaa929800 | ||
|
|
84d206ced4 | ||
|
|
93de0030bb | ||
|
|
10bddd8a17 | ||
|
|
0f0eae6bd7 | ||
|
|
8f6e33bd79 | ||
|
|
05e2c5c52c | ||
|
|
49359cc221 | ||
|
|
dd641937eb | ||
|
|
d534aa41d5 | ||
|
|
519474da1c | ||
|
|
df195ee75c | ||
|
|
103a2fc2ae | ||
|
|
e363d48356 | ||
|
|
989ab9bf05 | ||
|
|
45cd12b77e | ||
|
|
ab84a43d33 | ||
|
|
5e65fcba13 | ||
|
|
625e696f68 | ||
|
|
7330928dca | ||
|
|
98a63cefa9 | ||
|
|
8c2c0f45b5 | ||
|
|
8a346da051 | ||
|
|
5ba63020d1 | ||
|
|
2aa43a8063 | ||
|
|
a22085d8db | ||
|
|
df1421b163 | ||
|
|
f871b5561e | ||
|
|
d6bccde06d | ||
|
|
989fa57047 | ||
|
|
48001b6115 | ||
|
|
180f901594 | ||
|
|
33da94a4bd | ||
|
|
198da97f0e | ||
|
|
c072052b38 | ||
|
|
c1f8cc0f7b | ||
|
|
db81a4a3e7 | ||
|
|
75c25c813d | ||
|
|
3b05013b62 | ||
|
|
4369b1f288 | ||
|
|
4700ea92db | ||
|
|
182dd322a5 | ||
|
|
1ba2d767a8 | ||
|
|
fc36eed4cd | ||
|
|
612e589016 | ||
|
|
1859eb0310 | ||
|
|
2ac67e04b6 | ||
|
|
f6467e8671 | ||
|
|
c304415b07 | ||
|
|
7a10702355 | ||
|
|
112a94c69d | ||
|
|
2ec05940f7 | ||
|
|
b3f8cce0ae | ||
|
|
7cbb9d081b | ||
|
|
8409a62a6a | ||
|
|
c4fae3c1dd | ||
|
|
a1be614279 | ||
|
|
ce3f7f2224 | ||
|
|
55eef6370e | ||
|
|
ee0fac37f9 | ||
|
|
2cf86f41fa | ||
|
|
74e79a6c59 | ||
|
|
c3bfc44ec3 | ||
|
|
24b79880d0 | ||
|
|
cea46daba9 | ||
|
|
afbc00d78c | ||
|
|
b5a085dd23 | ||
|
|
849ec56421 | ||
|
|
41318639f8 | ||
|
|
eb552ab7a2 | ||
|
|
f85205afb8 | ||
|
|
1a8cfb91e7 | ||
|
|
a457e797ee | ||
|
|
e418b04c3e | ||
|
|
abf2ee968a | ||
|
|
7f1b8c8aa6 | ||
|
|
f399c2e9fa | ||
|
|
a62d69c1c4 | ||
|
|
3dfeaabe2f | ||
|
|
5ff9dbb67e | ||
|
|
ae02d6aea0 | ||
|
|
50acf56ec8 | ||
|
|
eeab786848 | ||
|
|
6cb33ca334 | ||
|
|
c20036297f | ||
|
|
20ad992a7b | ||
|
|
eaaf213902 | ||
|
|
b3c044ab65 | ||
|
|
6cbcdb694d | ||
|
|
0834acc020 | ||
|
|
e50f5f0935 | ||
|
|
f86e871f07 | ||
|
|
ceb1826bed | ||
|
|
36dff411fd | ||
|
|
90e0a99486 | ||
|
|
c51fa1fcae | ||
|
|
9cdbc5b981 | ||
|
|
7542fa8032 | ||
|
|
b1bb684a04 | ||
|
|
ade954ab69 | ||
|
|
9f8adfee9b | ||
|
|
297c246570 | ||
|
|
13e6712721 | ||
|
|
dce4496393 | ||
|
|
db24d6e435 | ||
|
|
3bd2eb431a | ||
|
|
e247c99cd5 | ||
|
|
072f0f7562 | ||
|
|
392e729d57 | ||
|
|
f7748cc6db | ||
|
|
6d9172f635 | ||
|
|
c3e78ec8f5 | ||
|
|
5b9cf0f834 | ||
|
|
0381c72ca2 | ||
|
|
d156aba1f9 | ||
|
|
1388b8495c | ||
|
|
ef52d17303 | ||
|
|
9957fbfd33 | ||
|
|
ff2ebbb09f | ||
|
|
7d6b011362 | ||
|
|
e911e93aaf | ||
|
|
8b7c167592 | ||
|
|
868f332706 | ||
|
|
e654c5739e | ||
|
|
a6aff72d86 | ||
|
|
dc2f55570c | ||
|
|
22f21f752c | ||
|
|
78f65522b7 | ||
|
|
d14cf27acf | ||
|
|
94176776fb | ||
|
|
890f9262e0 | ||
|
|
f57e3bed00 | ||
|
|
08b112a20f | ||
|
|
83f3b80a8c | ||
|
|
ae7714aeff | ||
|
|
66c893e251 | ||
|
|
74c7d865d7 | ||
|
|
d4ebc44a98 | ||
|
|
8c08f55d8f | ||
|
|
8198da1aa4 | ||
|
|
92a3501c81 | ||
|
|
aac4a51f23 | ||
|
|
1b3e85f0fb | ||
|
|
c6eee95a55 | ||
|
|
4ce0e1f657 | ||
|
|
98463d6774 | ||
|
|
7d022f709b | ||
|
|
fd8a9195fb | ||
|
|
57f78d1a6b | ||
|
|
8ad2bdbb29 | ||
|
|
0fa5ef45e2 | ||
|
|
257f784318 | ||
|
|
e66d997557 | ||
|
|
7e85253f26 | ||
|
|
e84a1bc3ea | ||
|
|
f4daaa91a4 | ||
|
|
5c3f75d504 | ||
|
|
0901e77866 | ||
|
|
621175533b | ||
|
|
565400eec5 | ||
|
|
9d5e792b34 | ||
|
|
ee62847781 | ||
|
|
077fd2bf21 | ||
|
|
982b6c08d9 | ||
|
|
ad80432252 | ||
|
|
4a9825cd57 | ||
|
|
153b494e61 | ||
|
|
d9bed4563e | ||
|
|
2e2d2bebd7 | ||
|
|
77cc5d14a9 | ||
|
|
99dadbc17c | ||
|
|
663a532967 | ||
|
|
c615fd239b | ||
|
|
a8b29e44f3 | ||
|
|
6156c4c765 | ||
|
|
a94fa2917e | ||
|
|
1be2007b9e | ||
|
|
fb0dde5ef8 | ||
|
|
0451620de9 | ||
|
|
ef7bdc4b29 | ||
|
|
f0ac9973d0 | ||
|
|
34fc468265 | ||
|
|
0046ba9a2c | ||
|
|
c37a97308e | ||
|
|
81390b846c | ||
|
|
c24dbb2b98 | ||
|
|
6726f1be88 | ||
|
|
be5a148d88 | ||
|
|
e15546e051 | ||
|
|
47774eacab | ||
|
|
6092737c9c | ||
|
|
f2fb76341e | ||
|
|
cb37a34c8b | ||
|
|
60c3ff8a41 | ||
|
|
0f37e64f35 | ||
|
|
5244ea9e79 | ||
|
|
f11962ef8e | ||
|
|
4862827058 | ||
|
|
2150b04349 | ||
|
|
001bbaaeec | ||
|
|
04d5fcd9a4 | ||
|
|
cc8d62969f | ||
|
|
ee4855cd14 | ||
|
|
ea600edcd2 | ||
|
|
1a60676f44 | ||
|
|
5943b0c5e5 | ||
|
|
77caac761f | ||
|
|
df29795904 | ||
|
|
5264f2f4d2 | ||
|
|
cae65413ee | ||
|
|
9a19ae21aa | ||
|
|
a86411682b | ||
|
|
77fd7f0e5d | ||
|
|
ac12f7fe1a | ||
|
|
508e766ea5 | ||
|
|
3a10e437c8 | ||
|
|
a8d2f3bd39 | ||
|
|
d1abba5378 | ||
|
|
242a1ce108 | ||
|
|
09c673fbd0 | ||
|
|
bbd1ce6168 | ||
|
|
1bdf833e2c | ||
|
|
daf0430c6f | ||
|
|
06b685df21 | ||
|
|
dfd70b8d63 | ||
|
|
b379b94f97 | ||
|
|
00d204be75 | ||
|
|
3526355842 | ||
|
|
76510fee5c | ||
|
|
7daf65c01c | ||
|
|
f036deef33 | ||
|
|
6f0940e4b5 | ||
|
|
97c533c7c5 | ||
|
|
fdad9afc05 | ||
|
|
db81d1a28b | ||
|
|
eb250cc178 | ||
|
|
d98ce895f8 | ||
|
|
b91871114a | ||
|
|
aeb4bc6245 | ||
|
|
6b47216266 | ||
|
|
c7dbee6375 | ||
|
|
de6069b7d0 | ||
|
|
f9727ec384 | ||
|
|
b939f9d4a3 | ||
|
|
b59dc1cc14 | ||
|
|
3fee1c5d20 | ||
|
|
606fac6fa5 | ||
|
|
8058a3c3e0 | ||
|
|
b3731be4b1 | ||
|
|
52af91e066 | ||
|
|
280511b990 | ||
|
|
83db582b92 | ||
|
|
490c865ea1 | ||
|
|
9fe5004756 | ||
|
|
86765620d7 | ||
|
|
02c051f47c | ||
|
|
2c2df76f15 | ||
|
|
1f6ef60599 | ||
|
|
85bc2c8792 | ||
|
|
1131480f44 | ||
|
|
b92352c480 | ||
|
|
1831141abd | ||
|
|
332831a8cc | ||
|
|
0fc1ec5c93 | ||
|
|
7c2fcf6e2a | ||
|
|
8e99303e2f | ||
|
|
a8357047b2 | ||
|
|
995bb335b8 | ||
|
|
f8d0fda179 | ||
|
|
b801d793e6 | ||
|
|
b45e531127 | ||
|
|
7cef05148f | ||
|
|
a207ede5be | ||
|
|
a40e7961a1 | ||
|
|
8b7c9e10c3 | ||
|
|
d1b96c340f | ||
|
|
cf4baa1270 | ||
|
|
4eeba4e48b | ||
|
|
f5c32423bc | ||
|
|
e7f9116c30 | ||
|
|
7c60884847 | ||
|
|
d4f9ffbc6b | ||
|
|
fbcaeeb6a2 | ||
|
|
41ecdeccd0 | ||
|
|
fb136ba200 | ||
|
|
81756bfb05 | ||
|
|
31372884ea | ||
|
|
b574faed39 | ||
|
|
fdbb6752f9 | ||
|
|
462fe228aa | ||
|
|
462ceffeb7 | ||
|
|
2bce5224f6 | ||
|
|
f888cc94ba | ||
|
|
51a1c6eb5b | ||
|
|
a85f962a47 | ||
|
|
052475d492 | ||
|
|
d211f0977d | ||
|
|
81c4913c72 | ||
|
|
462f786c18 | ||
|
|
82a6e66269 | ||
|
|
136a8365b1 | ||
|
|
edca77176f | ||
|
|
aba91a61a0 | ||
|
|
3ac12fba98 | ||
|
|
4790b02168 | ||
|
|
efde97c169 | ||
|
|
8485115118 | ||
|
|
2f21caca71 | ||
|
|
29457ea214 | ||
|
|
fd5a035453 | ||
|
|
d3d7225a79 | ||
|
|
d427fee7ee | ||
|
|
eebed062ad | ||
|
|
1b5420c33b | ||
|
|
158658c3fc | ||
|
|
def32eda19 | ||
|
|
41989e1151 | ||
|
|
39a6474820 | ||
|
|
ef1c610c58 | ||
|
|
07dd8eba32 | ||
|
|
b60a3f95b8 | ||
|
|
4cc218a450 | ||
|
|
8f9e7f3990 | ||
|
|
5f07834b47 | ||
|
|
0fb8a2d2ff | ||
|
|
59d6099865 | ||
|
|
8ba8a3b43a | ||
|
|
e0522bce3f | ||
|
|
f8c4ee1183 | ||
|
|
fcc736bd45 | ||
|
|
56e75fc46e | ||
|
|
b951a844ca | ||
|
|
e6e0bb5287 | ||
|
|
4add4bc237 | ||
|
|
dc49632ddc | ||
|
|
62fd42edc6 | ||
|
|
621083947c | ||
|
|
9bc1af2f0f | ||
|
|
e73e0ba5f1 | ||
|
|
c9571fb3ed | ||
|
|
1db0b09378 | ||
|
|
4f824a04a8 | ||
|
|
6ec8ca174f | ||
|
|
1d5c5b39a5 | ||
|
|
f6954a33a6 | ||
|
|
263de80c6c | ||
|
|
93bfdbc45d | ||
|
|
27d8fb3ac1 | ||
|
|
32e34cb656 | ||
|
|
9799120899 | ||
|
|
6a1781b9ed | ||
|
|
68a9dea630 | ||
|
|
1bc9a0bcc3 | ||
|
|
915cc50228 | ||
|
|
5fe4a5db4c | ||
|
|
dad5a2e004 | ||
|
|
c28e80e836 | ||
|
|
39822a9864 | ||
|
|
3eebb5438b | ||
|
|
7707ea860d | ||
|
|
52a692030e | ||
|
|
b662ee1aa2 | ||
|
|
39f7403b78 | ||
|
|
56f4b14ef6 | ||
|
|
363c844eec | ||
|
|
f6d979a084 | ||
|
|
1d52dd7433 | ||
|
|
349b3eb108 | ||
|
|
26a24be24e | ||
|
|
94d5c0f5ba | ||
|
|
d139b592ed | ||
|
|
088862634d | ||
|
|
c41d73b850 | ||
|
|
8cab372267 | ||
|
|
bc9d44b476 | ||
|
|
25ce672106 | ||
|
|
1d149c3f75 | ||
|
|
a7bc7bb16f | ||
|
|
5e1022bb86 | ||
|
|
ec899e6920 | ||
|
|
ab100bf3bc | ||
|
|
bac0c76a6d | ||
|
|
174722f387 | ||
|
|
3d916a90d4 | ||
|
|
8fc0274044 | ||
|
|
a03d15fd2f | ||
|
|
2cc61c3804 | ||
|
|
c585594197 | ||
|
|
1c227f7270 | ||
|
|
1099b358a0 | ||
|
|
0264711f9f | ||
|
|
8fb73c95f4 | ||
|
|
9d37b4a59b | ||
|
|
ba29011021 | ||
|
|
6ea1a8f840 | ||
|
|
331cbce5c9 | ||
|
|
a44572f9bf | ||
|
|
41ed037935 | ||
|
|
ad03d3e4ba | ||
|
|
c414664200 | ||
|
|
cdaf04eaed | ||
|
|
155959b430 | ||
|
|
ae9ec4c1d8 | ||
|
|
d7232abb60 | ||
|
|
2604212a97 | ||
|
|
59ffef2bf2 | ||
|
|
3065c077be | ||
|
|
22d4825e2c | ||
|
|
da9520466d | ||
|
|
7a4b88e7b5 | ||
|
|
320c905578 | ||
|
|
050aa3096b | ||
|
|
c205e1b314 | ||
|
|
d31c146a7b | ||
|
|
b765749c3d | ||
|
|
5ada00af9f | ||
|
|
88d7c37424 | ||
|
|
2bfe845f6d | ||
|
|
08b4d10367 | ||
|
|
3e9bbbffe3 | ||
|
|
bab0628f0a | ||
|
|
d0ee590a1c | ||
|
|
6d5a900c3e | ||
|
|
0510a02447 | ||
|
|
f4609159fc | ||
|
|
85967e46f3 | ||
|
|
ac18ab9c19 | ||
|
|
0a52d6922e | ||
|
|
ed2f6097ef | ||
|
|
f44288082c | ||
|
|
964cc4b91a | ||
|
|
81fe427352 | ||
|
|
e02bc96ce2 | ||
|
|
437a0d39b7 | ||
|
|
f6f995d407 | ||
|
|
9452540c75 | ||
|
|
f039b3b77e | ||
|
|
f30c0aa619 | ||
|
|
628bd4f4b2 | ||
|
|
3da911edf4 | ||
|
|
7304c0c0d0 | ||
|
|
84ce67a816 | ||
|
|
e8e57e5e94 | ||
|
|
3f9b41e891 | ||
|
|
f91dfd7b69 | ||
|
|
5d35a80cf7 | ||
|
|
a9b400f076 | ||
|
|
382b5594f0 | ||
|
|
0445b3547c | ||
|
|
608356cc9b | ||
|
|
2198918231 | ||
|
|
09b967e82b | ||
|
|
e81962f774 | ||
|
|
f552c83f23 | ||
|
|
907b5d578e | ||
|
|
461aaedd56 | ||
|
|
8fd1fefdf9 | ||
|
|
89b2489727 | ||
|
|
d8bbb1e8ca | ||
|
|
941f958742 | ||
|
|
ae287ca56d | ||
|
|
57983b0a4f | ||
|
|
f65e17f3ac | ||
|
|
15d607d686 | ||
|
|
bd21224a9d | ||
|
|
b89e457414 | ||
|
|
7fb1a8851e | ||
|
|
45fc44e59f | ||
|
|
4ac878029d | ||
|
|
2dc8e6bd12 | ||
|
|
2c3ebee6ca | ||
|
|
336393aad6 | ||
|
|
5df54bc6fd | ||
|
|
c3ef70efc0 | ||
|
|
684a209c84 | ||
|
|
8a1ddec0f0 | ||
|
|
a96e8e9ef0 | ||
|
|
71b7e9c8f5 | ||
|
|
6828269137 | ||
|
|
3eedd25b48 | ||
|
|
c83cd1cb2d | ||
|
|
227481f0b8 | ||
|
|
48968766a0 | ||
|
|
e7794723bf | ||
|
|
47bb48c8b4 | ||
|
|
7a4d42ba93 | ||
|
|
32bdd461f6 | ||
|
|
c3f1123187 | ||
|
|
3a2ef5efdd | ||
|
|
389cd70e7e | ||
|
|
7b6faa3280 | ||
|
|
0a6c226a5b | ||
|
|
c4c6b8a051 | ||
|
|
0e9894012b | ||
|
|
0ef6074a6b | ||
|
|
9eab1f5e5b | ||
|
|
639a9c7459 | ||
|
|
c30c5a6437 | ||
|
|
917f21e468 | ||
|
|
40663d7f3d | ||
|
|
adabd69598 | ||
|
|
f9126620c8 | ||
|
|
b4c1ca7fcb | ||
|
|
ad35748d5c | ||
|
|
fac1974589 | ||
|
|
14e48f24b5 | ||
|
|
6dcfb7b058 | ||
|
|
c6f7d4d38a | ||
|
|
b75153d263 | ||
|
|
fdb5f82815 | ||
|
|
6950195741 | ||
|
|
d2ca0c35f1 | ||
|
|
a6f6a9734a | ||
|
|
207b3cebc5 | ||
|
|
ae62931fbb | ||
|
|
afd5c22264 | ||
|
|
825002c181 | ||
|
|
60df79fa4d | ||
|
|
424676c469 | ||
|
|
11376d6d3d | ||
|
|
32210b399c | ||
|
|
5b78631fdc | ||
|
|
285ad8f54c | ||
|
|
c73e87c8c7 | ||
|
|
99b5e4eec9 | ||
|
|
31c917192d | ||
|
|
6a4723f2f5 | ||
|
|
350b99778b | ||
|
|
b2b07a9d6e | ||
|
|
58f924cff4 | ||
|
|
815c6c14a0 | ||
|
|
c77b9130f3 | ||
|
|
082a2b7e99 | ||
|
|
e58ff3fbd8 | ||
|
|
04f0b785b5 | ||
|
|
3f01182f92 | ||
|
|
42efbcd553 | ||
|
|
2c3e9ec365 | ||
|
|
83877497cc | ||
|
|
0c70aadd46 | ||
|
|
03bf58f64c | ||
|
|
d94d1f16dd | ||
|
|
ad816cde01 | ||
|
|
23d0061fb1 | ||
|
|
3c0ad4816b | ||
|
|
3c01f5b037 | ||
|
|
60f96f3244 | ||
|
|
5bf4dbc30f | ||
|
|
4f798e2454 | ||
|
|
e6183cddec | ||
|
|
5cda17b800 | ||
|
|
be45e63e90 | ||
|
|
da26366c0b | ||
|
|
677bbe18b2 | ||
|
|
3280a71bbb | ||
|
|
30cc54b9c3 | ||
|
|
4b7f570947 | ||
|
|
276de14ff6 | ||
|
|
43ac88c90b | ||
|
|
8e86a65875 | ||
|
|
27ea5e63c3 | ||
|
|
aa37affe34 | ||
|
|
3d7e3cae6f | ||
|
|
f3d059d4d7 | ||
|
|
34540fff54 | ||
|
|
57f54b325c | ||
|
|
67e4c81676 | ||
|
|
3a4f272a01 | ||
|
|
485045408c | ||
|
|
e9709fcde6 | ||
|
|
d8fa619c2e | ||
|
|
3c8cd5219e | ||
|
|
745798def7 | ||
|
|
8bc4a40662 | ||
|
|
8124595a38 | ||
|
|
5e4e098f64 | ||
|
|
625661714f | ||
|
|
b10286422c | ||
|
|
a3f093e254 | ||
|
|
64ab933492 | ||
|
|
5e8c2dfdc7 | ||
|
|
928c9fe3f5 | ||
|
|
8799352a31 | ||
|
|
a2d06b849b | ||
|
|
b635a601be | ||
|
|
54ad5df47f | ||
|
|
2610fd5be7 | ||
|
|
5940292bb6 | ||
|
|
4beb1ba437 | ||
|
|
6647cd6a05 | ||
|
|
ab3882b489 | ||
|
|
c60c8394b3 | ||
|
|
922adde120 | ||
|
|
2e39da65f4 | ||
|
|
808b1b19a5 | ||
|
|
913ca308d2 | ||
|
|
2ebd800482 | ||
|
|
ae05aa499e | ||
|
|
6d22708b66 | ||
|
|
e2f066492f | ||
|
|
7917a0143a | ||
|
|
c6e6ed89dc | ||
|
|
1ff1a70bfb | ||
|
|
81722bfa4d | ||
|
|
1d542d88bc | ||
|
|
da1761b7c1 | ||
|
|
bd8d059f32 | ||
|
|
dc6ecfd9e3 | ||
|
|
7436c165a5 | ||
|
|
c47611525f | ||
|
|
659f60c23b | ||
|
|
b87f7b6e89 | ||
|
|
871520cef7 | ||
|
|
084df830ef | ||
|
|
326ee0ae67 | ||
|
|
fc760e90e0 | ||
|
|
c0ca96cb96 | ||
|
|
1fac76f80c | ||
|
|
18f78cfd3e | ||
|
|
ba24d578f6 | ||
|
|
294b42f5a4 | ||
|
|
fa7eb7f916 | ||
|
|
446d969779 | ||
|
|
b7ad90c245 | ||
|
|
9e815edc29 | ||
|
|
5d03973e80 | ||
|
|
1d2f74b5b0 | ||
|
|
6c3f632990 | ||
|
|
9ad14e2392 | ||
|
|
8f2754b0f7 | ||
|
|
04f374a4da | ||
|
|
9895c4d47d | ||
|
|
976ef858d0 | ||
|
|
6cb051ec52 | ||
|
|
d78229a875 | ||
|
|
8fb0d9019b | ||
|
|
6ab3ecd0cc | ||
|
|
a22ac6beab | ||
|
|
dc9dd8e8ca | ||
|
|
9d25a7663d | ||
|
|
019ae62c2a | ||
|
|
b0226fe1e8 | ||
|
|
96fd7b1808 | ||
|
|
7290a52cf7 | ||
|
|
0e9edd0874 | ||
|
|
11857925d2 | ||
|
|
36e2a0b6ec | ||
|
|
bcb16757bb | ||
|
|
5db3d11b9a | ||
|
|
b7d928d043 | ||
|
|
0b84b88f57 | ||
|
|
ab305429fb | ||
|
|
391997ee09 | ||
|
|
1ee2167c2a | ||
|
|
8c8c09097d | ||
|
|
45b27c34ed | ||
|
|
cc1a39ebd7 | ||
|
|
2d2cb3d8ea | ||
|
|
2430231dc1 | ||
|
|
2ec195b9e8 | ||
|
|
5617d6b27e | ||
|
|
c15ae9670a | ||
|
|
f98b97e20a | ||
|
|
1e47726176 | ||
|
|
3bdcf371d1 | ||
|
|
a4f2cd8c11 | ||
|
|
b0995506ef | ||
|
|
57c87db9a1 | ||
|
|
d56c9baccf | ||
|
|
147fadefd9 | ||
|
|
b9a21ae296 | ||
|
|
768a459565 | ||
|
|
bfbf6e7dcf | ||
|
|
8f4a3112d1 | ||
|
|
d12ed64fd6 | ||
|
|
18bc22fd3e | ||
|
|
56d0c81af8 | ||
|
|
1628c51bd6 | ||
|
|
e92da9b2db | ||
|
|
dc0411746e | ||
|
|
27fd30ef5f | ||
|
|
26a4abd3f5 | ||
|
|
1d5cd55452 | ||
|
|
bd2fc6dbfe | ||
|
|
b4e5839681 | ||
|
|
af2a9a7110 | ||
|
|
4485e0e932 | ||
|
|
1c57cae1ed | ||
|
|
b498f5a744 | ||
|
|
782bcba9f7 | ||
|
|
98bec91318 | ||
|
|
57dabc1ab5 | ||
|
|
99311e4820 | ||
|
|
dcfdc4fc36 | ||
|
|
bf7470d712 | ||
|
|
3865aaad83 | ||
|
|
8d96efb6f5 | ||
|
|
88940645c0 | ||
|
|
341c55945c | ||
|
|
866449c8ee | ||
|
|
ff851d36d6 | ||
|
|
183ddeac5f | ||
|
|
cc38eef867 | ||
|
|
a6f95d70d5 | ||
|
|
b819360605 | ||
|
|
ee04d84abd | ||
|
|
f77072fbd2 | ||
|
|
fa34bcbea3 | ||
|
|
21b231bced | ||
|
|
0fb98bc071 | ||
|
|
ea8dad4220 | ||
|
|
8b1f7dcba0 | ||
|
|
587a618400 | ||
|
|
c57c3527d2 | ||
|
|
6c48811167 | ||
|
|
642953eaf1 | ||
|
|
7033755762 | ||
|
|
fdb4304f70 | ||
|
|
0bdecc9a4a | ||
|
|
988bf98d4a | ||
|
|
8c0c75253e | ||
|
|
d55bd64d6b | ||
|
|
21568a4b8d | ||
|
|
f8b50f66ec | ||
|
|
b856a1a529 | ||
|
|
5eee238729 | ||
|
|
474626b779 | ||
|
|
52c7b7f25c | ||
|
|
4d51086cd1 | ||
|
|
a473c5c221 | ||
|
|
381d62a733 | ||
|
|
d5206276a8 | ||
|
|
0307fe1aa9 | ||
|
|
4cc4fc0ffe | ||
|
|
a3a4e84965 | ||
|
|
d478b3382e | ||
|
|
b8930bd10a | ||
|
|
d700a1bd1a | ||
|
|
72fe10c00a | ||
|
|
b3568c0142 | ||
|
|
a7bd07b3ce | ||
|
|
8a5ff459a7 | ||
|
|
bff6e20946 | ||
|
|
f323246d4f | ||
|
|
c969e46519 | ||
|
|
1c42ea0a7c | ||
|
|
49b2255020 | ||
|
|
03c6cf9d51 | ||
|
|
a9780aa8be | ||
|
|
9ec3d258bd | ||
|
|
29d3476d68 | ||
|
|
e4eee85274 | ||
|
|
5f7a396ced | ||
|
|
aeccf550e3 | ||
|
|
c8c1dd9c10 | ||
|
|
2398b48e29 | ||
|
|
88f45a4166 | ||
|
|
522b72d9df | ||
|
|
51cb56b064 | ||
|
|
09044d1959 | ||
|
|
38820a4f89 | ||
|
|
b96c87baf9 | ||
|
|
d426e16216 | ||
|
|
f613520ee9 | ||
|
|
56c5710b3f | ||
|
|
0b661442c5 | ||
|
|
d589a215ad | ||
|
|
a8b0e9848b | ||
|
|
0031151008 | ||
|
|
8a560bfbbb | ||
|
|
5417ae2155 | ||
|
|
65bce62b26 | ||
|
|
d22d83f2c8 | ||
|
|
12c99e9144 | ||
|
|
a3844a0149 | ||
|
|
cf9d077057 | ||
|
|
7c622942e7 | ||
|
|
d89d68e816 | ||
|
|
8c49962102 | ||
|
|
ea4aea46d4 | ||
|
|
19033c018d | ||
|
|
32bdecb828 | ||
|
|
086957fd3f | ||
|
|
7eeea3684b | ||
|
|
6f16fdc9d5 | ||
|
|
dcc1bd8cb7 | ||
|
|
b85eda9649 | ||
|
|
c210b5941e | ||
|
|
de72e05a45 | ||
|
|
31b2192f22 | ||
|
|
2480976308 | ||
|
|
5958f7760e | ||
|
|
9a3e3e443c | ||
|
|
056f8eab5f | ||
|
|
784fd1f433 | ||
|
|
293ca770de | ||
|
|
64203d4796 | ||
|
|
1ca508dc2e | ||
|
|
260d7c0054 | ||
|
|
b0aab772ef | ||
|
|
b560f1d3a9 | ||
|
|
ca3ba80fd8 | ||
|
|
3a1e9f3b72 | ||
|
|
8197caa4ef | ||
|
|
c39c27009b | ||
|
|
9a15a1796d | ||
|
|
4a2dfd7f4a | ||
|
|
fa7ae387bf | ||
|
|
bfc0fa8345 | ||
|
|
f9c82467cb | ||
|
|
03fc29d297 | ||
|
|
ccf8d06c8f | ||
|
|
f624082a62 | ||
|
|
cffd109179 | ||
|
|
346b190f97 | ||
|
|
aaaac827d1 | ||
|
|
4860cd945f | ||
|
|
6106e1600f | ||
|
|
2d8cd1538f | ||
|
|
824580de66 | ||
|
|
9cde0994fc | ||
|
|
9e5f7331b1 | ||
|
|
5551fb9df1 | ||
|
|
af892d719c | ||
|
|
7121a62b36 | ||
|
|
68d02e5572 | ||
|
|
040337eaf4 | ||
|
|
5196a56267 | ||
|
|
e3805d4138 | ||
|
|
b334a4224d | ||
|
|
dcbda8806e | ||
|
|
8fa9ef8d06 | ||
|
|
97dbc7847b | ||
|
|
f0c62ceef1 | ||
|
|
efad064619 | ||
|
|
1f3d2a7611 | ||
|
|
57ac1ca1fb | ||
|
|
21acf463ba | ||
|
|
8d3c7a1859 | ||
|
|
328453309a | ||
|
|
6606baebe9 | ||
|
|
4594e990a6 | ||
|
|
1e7e28a065 | ||
|
|
56150ef85f | ||
|
|
de208491dc | ||
|
|
b9b1fecbfa | ||
|
|
580d4ddf25 | ||
|
|
35d3408ab6 | ||
|
|
dcd4a5a8f1 | ||
|
|
dd4c51db97 | ||
|
|
a6cc5c0986 | ||
|
|
c79d497063 | ||
|
|
8d30252044 | ||
|
|
20c291dea2 | ||
|
|
b79c1e7a2f | ||
|
|
825c2d340b | ||
|
|
810beae712 | ||
|
|
7ba9bd6e67 | ||
|
|
9c43e63d1b | ||
|
|
0fe4c5e6f8 | ||
|
|
931d33eb11 | ||
|
|
6f712f4f01 | ||
|
|
8d0e25c8a6 | ||
|
|
5c4bf2ad89 | ||
|
|
92bdce5eb1 | ||
|
|
d7f68775ce | ||
|
|
877d868745 | ||
|
|
82e7b3d813 | ||
|
|
c6a3750ea5 | ||
|
|
fd5636229d | ||
|
|
a69a1cc930 | ||
|
|
fd41ef179e | ||
|
|
2a4455aa9c | ||
|
|
7ed82106a3 | ||
|
|
982744b6c9 | ||
|
|
cccf49d8bd | ||
|
|
082c101845 | ||
|
|
c8ba301d45 | ||
|
|
2701c43161 | ||
|
|
dd73ec092b | ||
|
|
03fd4f030b | ||
|
|
2c8399dfcf | ||
|
|
229f040d43 | ||
|
|
b2788ca1ee | ||
|
|
2dbc4f9a9d | ||
|
|
2fac781a0a | ||
|
|
07ebb83cac | ||
|
|
52aff2a304 | ||
|
|
53286700f7 | ||
|
|
c3a9624040 | ||
|
|
1dbc6ea740 | ||
|
|
26dea9aa33 | ||
|
|
d686f982cc | ||
|
|
7cdad0b4ed | ||
|
|
04084b31aa | ||
|
|
48fa2a027d | ||
|
|
8586202ae2 | ||
|
|
445943d253 | ||
|
|
1682a41e40 | ||
|
|
7c302ba456 | ||
|
|
ab32774e68 | ||
|
|
2633a7711d | ||
|
|
e2400a535c | ||
|
|
42cf223f4e | ||
|
|
5f1c2a3e8c | ||
|
|
0838624a79 | ||
|
|
9fad7db460 | ||
|
|
5f7f902ba1 | ||
|
|
9bc2cb5328 | ||
|
|
e95eb28fe6 | ||
|
|
518478c793 | ||
|
|
f77eedf4b4 | ||
|
|
b5703e8177 | ||
|
|
a97284c18d | ||
|
|
6703f3b74c | ||
|
|
22f30c06f7 | ||
|
|
60cfebfcfa | ||
|
|
f2892e5927 | ||
|
|
4cc4d83ef9 | ||
|
|
f45e316a8c | ||
|
|
2c5f0ee332 | ||
|
|
164627f794 | ||
|
|
39b7b08932 | ||
|
|
127d5bc676 | ||
|
|
5b1348d123 | ||
|
|
2f9cd64489 | ||
|
|
81eacdda24 | ||
|
|
c33adf6cf7 | ||
|
|
d29ce909a0 | ||
|
|
aaf957af4e | ||
|
|
eb107c9b54 | ||
|
|
40b40b7fa5 | ||
|
|
a28bfc157b | ||
|
|
9d372a54cc | ||
|
|
b5b29fcb32 | ||
|
|
f7fc9dc564 | ||
|
|
e15c2201ee | ||
|
|
a69218877c | ||
|
|
f4953e6394 | ||
|
|
b6ca264e88 | ||
|
|
3279f78ced | ||
|
|
00935edaa1 | ||
|
|
97e9339bc9 | ||
|
|
6fb53c08d5 | ||
|
|
f7cf537454 | ||
|
|
83bc6af3a6 | ||
|
|
f5294a19d7 | ||
|
|
5b08693ba2 | ||
|
|
b084b075e6 | ||
|
|
78267d5111 | ||
|
|
f982a5e67b | ||
|
|
b4a7805033 | ||
|
|
6bec8936a9 | ||
|
|
67deaf3949 | ||
|
|
0f6f1077c5 | ||
|
|
1d59af182e | ||
|
|
060418d5d9 | ||
|
|
64901dcbbb | ||
|
|
2e8d44d005 | ||
|
|
c99293d94e | ||
|
|
64f2e37ffb | ||
|
|
716ee19f6c | ||
|
|
1fc2017db5 | ||
|
|
e7cc7906c5 | ||
|
|
41c5eba034 | ||
|
|
f66b6f155e | ||
|
|
add0f3df07 | ||
|
|
34f55f6024 | ||
|
|
331760cd5c | ||
|
|
42ad81285f | ||
|
|
14f73f3dd2 | ||
|
|
e768dc2d5f | ||
|
|
d0ee99fff2 | ||
|
|
1b565de9ce | ||
|
|
0a324564d5 | ||
|
|
206b3ffcd2 | ||
|
|
398dec28e9 | ||
|
|
0e8b6aecb7 | ||
|
|
5d0906aef6 | ||
|
|
f1448fde6e | ||
|
|
6d7ac7a06c | ||
|
|
0010dc8c81 | ||
|
|
d93a85c1d4 | ||
|
|
490e3e49f8 | ||
|
|
0a2654a761 | ||
|
|
ae2c3b113c | ||
|
|
d43ef1728c | ||
|
|
cb9ead08c7 | ||
|
|
e0509aafe1 | ||
|
|
99b8409738 | ||
|
|
05641bdec0 | ||
|
|
b09f30ed41 | ||
|
|
e1d2eb1ecd | ||
|
|
2872381c7d | ||
|
|
1f594e1004 | ||
|
|
0834762f6e | ||
|
|
091d171f02 | ||
|
|
86b11cca5f | ||
|
|
2232c87fdb | ||
|
|
82619da3fd | ||
|
|
aef2561f2a | ||
|
|
dc26d38a36 | ||
|
|
55d7b5e80e | ||
|
|
231239f43f | ||
|
|
5fc01b4100 | ||
|
|
768e41c933 | ||
|
|
cedb584722 | ||
|
|
234bb0bbe5 | ||
|
|
fb63612ebf | ||
|
|
c9869344e2 | ||
|
|
409c306474 | ||
|
|
05376b6173 | ||
|
|
09d0e3754f | ||
|
|
feee56990a | ||
|
|
b02d9bf1fa | ||
|
|
984a4c6ff3 | ||
|
|
99ec7049f7 | ||
|
|
4a9d3c654f | ||
|
|
c171dd329d | ||
|
|
584c3b0aa3 | ||
|
|
a2cfb95574 | ||
|
|
46b74f8e94 | ||
|
|
d27fa8a587 | ||
|
|
4579b1fd9c | ||
|
|
8e7f41cd08 | ||
|
|
4c91264062 | ||
|
|
366bb7301f | ||
|
|
9635d5933e | ||
|
|
ad55977d4a | ||
|
|
8863b071da | ||
|
|
a60eb57a47 | ||
|
|
51a33aaf0b | ||
|
|
a5bb6a2b7e | ||
|
|
7014a33285 | ||
|
|
e8d9671753 | ||
|
|
8deca61094 | ||
|
|
d5936b7fb5 | ||
|
|
4fdb89d651 | ||
|
|
c4e9a47048 | ||
|
|
2fd22922d5 | ||
|
|
1060cfd441 | ||
|
|
7db00165dd | ||
|
|
9d9018b455 | ||
|
|
eb460e885a | ||
|
|
8ca34eb81f | ||
|
|
f509b0fa01 | ||
|
|
75282a33c9 | ||
|
|
db89164e1e | ||
|
|
fb6b1fd54a | ||
|
|
939a822f65 | ||
|
|
4ab1cadfad | ||
|
|
97c36c0efc | ||
|
|
8d02b02ab4 | ||
|
|
f1ada661c1 | ||
|
|
90d7b9673c | ||
|
|
5e6196d541 | ||
|
|
e350aa0672 | ||
|
|
c478a04b48 | ||
|
|
928a64147c | ||
|
|
a57736ef2b | ||
|
|
62641ba4a6 | ||
|
|
5f205dd90b | ||
|
|
5115684dc2 | ||
|
|
a2566d4de5 | ||
|
|
68c9813390 | ||
|
|
0653a42984 | ||
|
|
a7d4459a01 | ||
|
|
7da6c582a0 | ||
|
|
684f59a73c | ||
|
|
97a09a6e33 | ||
|
|
9e5a1ea41b | ||
|
|
07d833473c | ||
|
|
31f5388f9e | ||
|
|
521af19e50 | ||
|
|
9605d80b99 | ||
|
|
67ede23694 | ||
|
|
5154713644 | ||
|
|
5bb7bd6c44 | ||
|
|
8fe3526ecd | ||
|
|
f9c7f30d2d | ||
|
|
8aedfbb7f3 | ||
|
|
b4fc05acfb | ||
|
|
5adbef5f68 | ||
|
|
b63dfdf587 | ||
|
|
6354bd300d | ||
|
|
53a74f78d7 | ||
|
|
b67106889e | ||
|
|
25974843e3 | ||
|
|
6d8c2283b9 | ||
|
|
df74f73d5b | ||
|
|
099172e44e | ||
|
|
4626695b52 | ||
|
|
8fbeb6eecc | ||
|
|
d90c4dfed2 | ||
|
|
803bb6a87d | ||
|
|
31d58909ce | ||
|
|
522b061fe6 | ||
|
|
63c0289e28 | ||
|
|
a0cc974323 | ||
|
|
20f874d146 | ||
|
|
de52c4f560 | ||
|
|
c754fcdb99 | ||
|
|
2148c3e1f7 | ||
|
|
cc51d012de | ||
|
|
ea547a012b | ||
|
|
8e535d53f4 | ||
|
|
5e08740456 | ||
|
|
72dc548e6e | ||
|
|
594ae07aa6 | ||
|
|
a8491cc5e0 | ||
|
|
74b80aaeeb |
2
.gitattributes
vendored
Normal file
2
.gitattributes
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
# Leave all line endings alone!
|
||||
* -text
|
||||
13
.github/pull_request_template.md
vendored
Normal file
13
.github/pull_request_template.md
vendored
Normal file
@@ -0,0 +1,13 @@
|
||||
<!--
|
||||
BEFORE YOU CREATE A PULL REQUEST:
|
||||
|
||||
- Please base all pull requests against the master branch
|
||||
- Include a clear description of your change
|
||||
- Reference related Issue(s) (e.g., "Resolves Issue #123")
|
||||
|
||||
Thank you for contributing to RomWBW! I will review your pull request as soon as possible.
|
||||
|
||||
-Wayne
|
||||
|
||||
DELETE EVERYTHING IN THIS COMMENT BLOCK AND REPLACE WITH YOUR COMMENTS
|
||||
-->
|
||||
75
.github/workflows/commit.yml
vendored
Normal file
75
.github/workflows/commit.yml
vendored
Normal file
@@ -0,0 +1,75 @@
|
||||
name: Commit Build
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- '**'
|
||||
tags-ignore:
|
||||
- '**'
|
||||
|
||||
jobs:
|
||||
buildLinux:
|
||||
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4.1.1
|
||||
|
||||
- name: Get Commit Ref
|
||||
run: |
|
||||
COMMIT_REF=$(git rev-parse --short $GITHUB_SHA)
|
||||
echo "COMMIT_REF: $COMMIT_REF"
|
||||
echo "COMMIT_REF=$COMMIT_REF" >>$GITHUB_ENV
|
||||
|
||||
- name: Build
|
||||
run: |
|
||||
export TZ='America/Los_Angeles'
|
||||
sudo apt-get install srecord
|
||||
make transpile-c-code
|
||||
make distlog --trace
|
||||
rm -rf .git*
|
||||
|
||||
- name: List Output
|
||||
run: |
|
||||
cd Binary
|
||||
ls -l
|
||||
find -type f -exec md5sum '{}' \;
|
||||
|
||||
- name: Upload Artifact
|
||||
uses: actions/upload-artifact@v4.3.0
|
||||
with:
|
||||
name: RomWBW-${{env.COMMIT_REF}}-Linux
|
||||
path: .
|
||||
|
||||
buildMacOS:
|
||||
runs-on: macOS-latest
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4.1.1
|
||||
|
||||
- name: Get Commit Ref
|
||||
run: |
|
||||
COMMIT_REF=$(git rev-parse --short $GITHUB_SHA)
|
||||
echo "COMMIT_REF: $COMMIT_REF"
|
||||
echo "COMMIT_REF=$COMMIT_REF" >>$GITHUB_ENV
|
||||
|
||||
- name: Build
|
||||
run: |
|
||||
export TZ='America/Los_Angeles'
|
||||
brew install srecord
|
||||
make distlog
|
||||
rm -rf .git*
|
||||
|
||||
- name: List Output
|
||||
run: |
|
||||
cd Binary
|
||||
ls -l
|
||||
find . -type f -exec md5 -r -- '{}' +;
|
||||
|
||||
- name: Upload Artifact
|
||||
uses: actions/upload-artifact@v4.3.0
|
||||
with:
|
||||
name: RomWBW-${{env.COMMIT_REF}}-MacOS
|
||||
path: .
|
||||
127
.github/workflows/release.yml
vendored
Normal file
127
.github/workflows/release.yml
vendored
Normal file
@@ -0,0 +1,127 @@
|
||||
name: Release Build
|
||||
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- '**'
|
||||
|
||||
jobs:
|
||||
build:
|
||||
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4.1.1
|
||||
|
||||
- name: Build
|
||||
run: |
|
||||
export TZ='America/Los_Angeles'
|
||||
sudo apt-get install libncurses-dev
|
||||
sudo apt-get install srecord
|
||||
make transpile-c-code
|
||||
make distlog --trace
|
||||
rm -rf .git*
|
||||
|
||||
- name: Create Package Archive
|
||||
run: |
|
||||
zip -r RomWBW-${{github.ref_name}}-Package.zip .
|
||||
|
||||
- name: Set Title
|
||||
run: |
|
||||
echo "Tag: ${{github.ref_name}}"
|
||||
if grep -q "dev" <<< "${{github.ref_name}}"; then
|
||||
TITLE="RomWBW Development Snapshot"
|
||||
elif grep -q "beta" <<< "${{github.ref_name}}"; then
|
||||
TITLE="RomWBW Beta Release"
|
||||
elif grep -q "pre" <<< "${{github.ref_name}}"; then
|
||||
TITLE="RomWBW Prerelease"
|
||||
elif grep -q "rc" <<< "${{github.ref_name}}"; then
|
||||
TITLE="RomWBW Release Candidate"
|
||||
else
|
||||
TITLE="RomWBW"
|
||||
fi
|
||||
echo "Title: $TITLE"
|
||||
echo "TITLE=$TITLE" >>$GITHUB_ENV
|
||||
|
||||
- name: Attach Package Archive
|
||||
uses: wwarthen/actions/packages/automatic-releases@built-packages
|
||||
with:
|
||||
repo_token: "${{secrets.GITHUB_TOKEN}}"
|
||||
draft: true
|
||||
prerelease: true
|
||||
title: "${{env.TITLE}} ${{github.ref_name}}"
|
||||
files: |
|
||||
RomWBW-${{github.ref_name}}-Package.zip
|
||||
|
||||
- name: Build Docs
|
||||
run: |
|
||||
export TZ='America/Los_Angeles'
|
||||
sudo apt-get install gpp pandoc
|
||||
pip install mkdocs
|
||||
make -C Source/Doc deploy_mkdocs
|
||||
mkdocs build -f Source/Doc/mkdocs.yml
|
||||
|
||||
- name: Deploy Docs
|
||||
uses: peaceiris/actions-gh-pages@v4
|
||||
# if: github.ref == 'refs/heads/master'
|
||||
with:
|
||||
github_token: ${{ secrets.GITHUB_TOKEN }}
|
||||
publish_dir: Source/Doc/site
|
||||
|
||||
# - name: Upload Package Archive
|
||||
# uses: AButler/upload-release-assets@v2.0.2
|
||||
# with:
|
||||
# repo-token: ${{secrets.github_token}}
|
||||
# files: |
|
||||
# RomWBW-${{env.PKGLBL}}-Package.zip
|
||||
|
||||
|
||||
# - name: Post SnapShot
|
||||
# uses: docker://antonyurchenko/git-release:latest
|
||||
# env:
|
||||
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
# RELEASE_NAME_PREFIX: "${{env.TITLE}} "
|
||||
# CHANGELOG_FILE: "none"
|
||||
# with:
|
||||
# args: |
|
||||
# RomWBW-SnapShot-Package.zip
|
||||
|
||||
# - name: Post SnapShot
|
||||
# uses: cb80/pubrel@latest
|
||||
# with:
|
||||
# replace: true
|
||||
# files: |
|
||||
# RomWBW-SnapShot-Package.zip
|
||||
|
||||
# - name: Post SnapShot
|
||||
# uses: wwarthen/actions/packages/automatic-releases@built-packages
|
||||
# with:
|
||||
# repo_token: "${{ secrets.GITHUB_TOKEN }}"
|
||||
# prerelease: true
|
||||
# title: "RomWBW Development SnapShot ${{env.GITHUB_REF_SLUG}}"
|
||||
# files: |
|
||||
# RomWBW-SnapShot-Package.zip
|
||||
|
||||
# - name: Remove Older Releases
|
||||
# uses: wwarthen/delete-release-action@v1.2
|
||||
# with:
|
||||
# release-drop: true
|
||||
# release-keep-count: 0
|
||||
# release-drop-tag: true
|
||||
# pre-release-drop: false
|
||||
# pre-release-keep-count: 0
|
||||
# pre-release-drop-tag: true
|
||||
# draft-drop: true
|
||||
# env:
|
||||
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
|
||||
# - name: Remove Older Releases
|
||||
# uses: s00d/delete-older-releases@0.2.1
|
||||
# with:
|
||||
# keep_latest: 1
|
||||
## delete_tag_pattern: beta # defaults to ""
|
||||
# delete_type: 'release'
|
||||
# delete_branch: 'main'
|
||||
# env:
|
||||
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
204
.gitignore
vendored
Normal file
204
.gitignore
vendored
Normal file
@@ -0,0 +1,204 @@
|
||||
# Not sure what patterns to apply
|
||||
# So ignoring all generated files explicitly
|
||||
|
||||
**/*.[Bb][Ii][Nn]
|
||||
**/*.[Cc][Oo][Mm]
|
||||
**/*.[Rr][Oo][Mm]
|
||||
**/*.com
|
||||
**/*.eeprom
|
||||
**/*.hex
|
||||
**/*.img
|
||||
**/*.lib
|
||||
**/*.lst
|
||||
**/*.o
|
||||
**/*.prn
|
||||
**/*.rel
|
||||
**/*.sym
|
||||
**/*.sys
|
||||
**/*.tmp
|
||||
**/*/font*.asm
|
||||
|
||||
Binary/**/*.mym
|
||||
Binary/**/*.pt3
|
||||
!Binary/CPNET/NetBoot/*/cpnos.sys
|
||||
|
||||
Source/**/eeprom
|
||||
Source/Apps/Assign.com
|
||||
Source/Apps/FDU/FDU.COM
|
||||
Source/Apps/Format.com
|
||||
Source/Apps/IntTest.com
|
||||
Source/Apps/Mode.com
|
||||
Source/Apps/OSLdr.com
|
||||
Source/Apps/RTC.com
|
||||
Source/Apps/SysCopy.com
|
||||
Source/Apps/SysGen.com
|
||||
Source/Apps/Talk.com
|
||||
Source/Apps/Timer.com
|
||||
Source/Apps/Tune/Tune.com
|
||||
Source/BPBIOS/bpsys.bak
|
||||
Source/BPBIOS/bpsys.dat
|
||||
Source/BPBIOS/def-ww.lib
|
||||
Source/CPM3/bios3.spr
|
||||
Source/CPM3/bnkbios3.spr
|
||||
Source/CPM3/gencpm.dat
|
||||
Source/CPM3/options.lib
|
||||
Source/CPM3/zpmbios3.spr
|
||||
Source/HBIOS/Blank512KB.dat
|
||||
Source/HBIOS/build.inc
|
||||
Source/Images/blank144
|
||||
Source/Images/blankhd
|
||||
Source/Prop/Spin/ParPortProp.list
|
||||
Source/Prop/Spin/PropIO.list
|
||||
Source/Prop/Spin/PropIO2.list
|
||||
Source/Prop/ParPortProp.list
|
||||
Source/Prop/PropIO.list
|
||||
Source/Prop/PropIO2.list
|
||||
Source/ZPM3/bnkbios3.spr
|
||||
Source/ZPM3/gencpm.com
|
||||
Source/ZPM3/gencpm.com
|
||||
Source/ZPM3/gencpm.dat
|
||||
|
||||
Tools/Linux
|
||||
Tools/Darwin
|
||||
|
||||
Tools/unix/bin2asm/bin2asm
|
||||
Tools/unix/cpmtools/cpmchattr
|
||||
Tools/unix/cpmtools/cpmchmod
|
||||
Tools/unix/cpmtools/cpmcp
|
||||
Tools/unix/cpmtools/cpmls
|
||||
Tools/unix/cpmtools/cpmrm
|
||||
Tools/unix/cpmtools/fsck.cpm
|
||||
Tools/unix/cpmtools/fsed.cpm
|
||||
Tools/unix/cpmtools/mkfs.cpm
|
||||
Tools/unix/lzsa/lzsa
|
||||
Tools/unix/uz80as/uz80as
|
||||
Tools/unix/zx/config.h
|
||||
Tools/unix/zx/zx
|
||||
|
||||
!Source/ver.lib
|
||||
!Source/Apps/FAT/FAT.COM
|
||||
!Source/Apps/ZMP/zmpx.com
|
||||
!Source/Apps/ZMD/zmdsubs.rel
|
||||
!Source/Apps/Test/vdctest/font.asm
|
||||
!Source/BPBIOS/bpbuild.com
|
||||
!Source/BPBIOS/movp112.com
|
||||
!Source/BPBIOS/*.lib
|
||||
!Source/BPBIOS/Z34RCP11/cledinst.com
|
||||
!Source/BPBIOS/Z34RCP11/cledsave.com
|
||||
!Source/CPNET/**
|
||||
!Source/Fonts/*
|
||||
!Source/Images/**
|
||||
!Source/RomDsk/**
|
||||
!Source/UBIOS/FSFAT.BIN
|
||||
!Source/UBIOS/UNA-BIOS.BIN
|
||||
!Source/ZCCP/*.[Cc][Oo][Mm]
|
||||
!Source/ZCPR-DJ/*.[Cc][Oo][Mm]
|
||||
!Source/ZPM3/*.[Cc][Oo][Mm]
|
||||
!Source/ZSDOS/*.[Cc][Oo][Mm]
|
||||
!Source/ZRC/*.bin
|
||||
!Source/ZRC512/*.bin
|
||||
!Source/EZ512/*.bin
|
||||
!Source/Z1RCC/*.bin
|
||||
!Source/ZZRCC/*.bin
|
||||
!Source/SZ80/*.bin
|
||||
!Tools/cpm/**
|
||||
!Tools/unix/zx/*
|
||||
!Tools/zx/*
|
||||
|
||||
Source/ZPM3/gencpm.com
|
||||
Source/ZPM3/startzpm.com
|
||||
Source/ZPM3/zccp.com
|
||||
Source/ZPM3/zpmldr.com
|
||||
Source/ZPM3/genbnk.dat
|
||||
|
||||
Source/ZSDOS/zsdos.err
|
||||
|
||||
# Lets explicit list all generate untracked binary files
|
||||
Binary/*.upd
|
||||
Binary/Apps/bbcbasic.txt
|
||||
Binary/Apps/copysl.doc
|
||||
Binary/Apps/copysl.doc
|
||||
Binary/Apps/fdu.doc
|
||||
Binary/Apps/fdu.doc
|
||||
Binary/Apps/Tunes/bgm.vgm
|
||||
Binary/Apps/Tunes/ending.vgm
|
||||
Binary/Apps/Tunes/inchina.vgm
|
||||
Binary/Apps/Tunes/shirakaw.vgm
|
||||
Binary/Apps/Tunes/startdem.vgm
|
||||
Binary/Apps/Tunes/wonder01.vgm
|
||||
Binary/Apps/zmconfig.ovr
|
||||
Binary/Apps/zminit.ovr
|
||||
Binary/Apps/zmp.cfg
|
||||
Binary/Apps/zmp.doc
|
||||
Binary/Apps/zmp.fon
|
||||
Binary/Apps/zmp.hlp
|
||||
Binary/Apps/zmterm.ovr
|
||||
Binary/Apps/zmxfer.ovr
|
||||
Binary/CPM3/bdos3.spr
|
||||
Binary/CPM3/bios3.spr
|
||||
Binary/CPM3/bnkbdos3.spr
|
||||
Binary/CPM3/bnkbios3.spr
|
||||
Binary/CPM3/cpm3fix.pat
|
||||
Binary/CPM3/genbnk.dat
|
||||
Binary/CPM3/gencpm.dat
|
||||
Binary/CPM3/genres.dat
|
||||
Binary/CPM3/readme.1st
|
||||
Binary/CPM3/resbdos3.spr
|
||||
Binary/CPNET/cpn12duo.lbr
|
||||
Binary/CPNET/cpn12mt.lbr
|
||||
Binary/CPNET/cpn12ser.lbr
|
||||
Binary/CPNET/cpn3duo.lbr
|
||||
Binary/CPNET/cpn3mt.lbr
|
||||
Binary/CPNET/cpn3ser.lbr
|
||||
Binary/hd1k_prefix.dat
|
||||
Binary/ZPM3/bnkbdos3.spr
|
||||
Binary/ZPM3/bnkbios3.spr
|
||||
Binary/ZPM3/gencpm.dat
|
||||
Binary/ZPM3/resbdos3.spr
|
||||
Binary/ZPM3/zinstal.zpm
|
||||
Source/BPBIOS/def-ww.lib
|
||||
Source/CPNET/cpn12duo.lbr
|
||||
Source/CPNET/cpn12mt.lbr
|
||||
Source/CPNET/cpn12ser.lbr
|
||||
Source/CPNET/cpn3duo.lbr
|
||||
Source/CPNET/cpn3mt.lbr
|
||||
Source/CPNET/cpn3ser.lbr
|
||||
Source/Fonts/font8x11c.asm
|
||||
Source/Fonts/font8x11c.bin
|
||||
Source/Fonts/font8x11u.asm
|
||||
Source/Fonts/font8x16c.asm
|
||||
Source/Fonts/font8x16c.bin
|
||||
Source/Fonts/font8x16u.asm
|
||||
Source/Fonts/font8x8c.asm
|
||||
Source/Fonts/font8x8c.bin
|
||||
Source/Fonts/font8x8u.asm
|
||||
Source/Fonts/font6x8c.asm
|
||||
Source/Fonts/font6x8c.bin
|
||||
Source/Fonts/font6x8u.asm
|
||||
Source/Fonts/fontcgac.asm
|
||||
Source/Fonts/fontcgac.bin
|
||||
Source/Fonts/fontcgau.asm
|
||||
Source/Fonts/fontvgarcc.asm
|
||||
Source/Fonts/fontvgarcc.bin
|
||||
Source/Fonts/fontvgarcu.asm
|
||||
Source/HBIOS/*.upd
|
||||
Source/HBIOS/build_env.cmd
|
||||
Source/HBIOS/build_env.cmd
|
||||
Source/HBIOS/hbios_env.sh
|
||||
Source/HBIOS/hbios_env.sh
|
||||
Source/HBIOS/netboot.mod
|
||||
Source/Images/*.cat
|
||||
Source/Images/*.img
|
||||
Source/Images/blank144
|
||||
Source/Images/blankhd1k
|
||||
Source/Images/blankhd512
|
||||
Source/RomDsk/*.cat
|
||||
Source/RomDsk/*.dat
|
||||
Source/ZCPR-DJ/zcprdemo.com
|
||||
Source/ZPM3/autotog.com
|
||||
Source/ZPM3/clrhist.com
|
||||
Source/ZPM3/cpmldr.com
|
||||
Source/ZPM3/setz3.com
|
||||
Tools/unix/OpenSpin/build/
|
||||
Tools/unix/zxcc/config.h
|
||||
Tools/unix/zxcc/zxcc
|
||||
38
.vscode/settings.json
vendored
Normal file
38
.vscode/settings.json
vendored
Normal file
@@ -0,0 +1,38 @@
|
||||
{
|
||||
"z80-macroasm.format.enabled": true,
|
||||
"z80-macroasm.format.baseIndent": 1,
|
||||
"z80-macroasm.format.whitespaceAfterInstruction": "tab",
|
||||
"z80-macroasm.format.uppercaseKeywords": true,
|
||||
"z80-macroasm.format.spaceAfterArgument": true,
|
||||
"z80-macroasm.format.hexaNumberStyle": "motorola",
|
||||
"z80-macroasm.format.hexaNumberCase": true,
|
||||
"files.trimTrailingWhitespace": false,
|
||||
"files.eol": "\r\n",
|
||||
"files.associations": {
|
||||
"*.inc": "z80-macroasm",
|
||||
"*.asm": "z80-macroasm",
|
||||
"*.180": "z80-macroasm",
|
||||
"*.asm.m4": "z80-macroasm",
|
||||
"*.inc.m4": "z80-macroasm",
|
||||
"*.mac": "z80-macroasm",
|
||||
"*.asmpp": "z80-macroasm",
|
||||
"*.zdsproj": "xml",
|
||||
"*.Z80": "z80-macroasm",
|
||||
"ch376.h": "c",
|
||||
"protocol.h": "c",
|
||||
"usb_state.h": "c",
|
||||
"functional": "c",
|
||||
"class_scsi.h": "c",
|
||||
"z80.h": "c",
|
||||
"dev_transfers.h": "c",
|
||||
"usb-base-drv.h": "c",
|
||||
"critical-section.h": "c",
|
||||
"enumerate.h": "c",
|
||||
"ch376inc.h": "c",
|
||||
"enumerate_storage.h": "c",
|
||||
"work-area.h": "c",
|
||||
"hbios-driver-storage.h": "c",
|
||||
"class_hid_keyboard.h": "c",
|
||||
"print.h": "c"
|
||||
}
|
||||
}
|
||||
File diff suppressed because it is too large
Load Diff
1163
Apps/Assign.asm
1163
Apps/Assign.asm
File diff suppressed because it is too large
Load Diff
@@ -1,26 +0,0 @@
|
||||
@echo off
|
||||
|
||||
setlocal
|
||||
|
||||
set PATH=..\Tools\tasm32;..\Tools\zx;%PATH%
|
||||
|
||||
set TASMTABS=..\Tools\tasm32
|
||||
|
||||
set ZXBINDIR=../tools/cpm/bin/
|
||||
set ZXLIBDIR=../tools/cpm/lib/
|
||||
set ZXINCDIR=../tools/cpm/include/
|
||||
|
||||
call :asm SysCopy || goto :eof
|
||||
call :asm Assign || goto :eof
|
||||
call :asm Format || goto :eof
|
||||
call :asm Talk || goto :eof
|
||||
|
||||
zx Z80ASM -SYSGEN/F
|
||||
|
||||
goto :eof
|
||||
|
||||
:asm
|
||||
echo.
|
||||
echo Building %1...
|
||||
tasm -t80 -b -g3 -fFF %1.asm %1.com %1.lst
|
||||
goto :eof
|
||||
@@ -1,4 +0,0 @@
|
||||
@echo off
|
||||
if exist *.bin del *.bin
|
||||
if exist *.com del *.com
|
||||
if exist *.lst del *.lst
|
||||
@@ -1,28 +0,0 @@
|
||||
;===============================================================================
|
||||
; FORMAT - DISK FORMAT UTILITY FOR ROMWBW ADAPTATION OF CP/M 2.2
|
||||
;===============================================================================
|
||||
;
|
||||
; AUTHOR: WAYNE WARTHEN (wwarthen@gmail.com)
|
||||
;_______________________________________________________________________________
|
||||
;
|
||||
; CHANGELOG:
|
||||
;_______________________________________________________________________________
|
||||
;
|
||||
; TODO:
|
||||
;
|
||||
;_______________________________________________________________________________
|
||||
;
|
||||
;
|
||||
;===============================================================================
|
||||
; MAIN PROGRAM PROCEDURE
|
||||
;===============================================================================
|
||||
;
|
||||
.ORG 00100H
|
||||
RET
|
||||
;
|
||||
STACKSAV .DW 0
|
||||
STACKSIZ .EQU 40H ; WE ARE A STACK PIG
|
||||
.FILL STACKSIZ,0
|
||||
STACK .EQU $
|
||||
;
|
||||
.END
|
||||
856
Apps/SysCopy.asm
856
Apps/SysCopy.asm
@@ -1,856 +0,0 @@
|
||||
;===============================================================================
|
||||
; SysCopy - Copy System Image to/from reserved tracks of disk for RomWBW
|
||||
; adaptation of CP/M 2.2
|
||||
;===============================================================================
|
||||
;
|
||||
; Author: Wayne Warthen (wwarthen@gmail.com)
|
||||
;_______________________________________________________________________________
|
||||
;
|
||||
; Usage:
|
||||
; SYSCOPY <dest>[=<src>]
|
||||
;
|
||||
; <dest> and <src> may be a drive or a file reference
|
||||
; If <src> is not specified, the system image will
|
||||
; be read from the current drive
|
||||
;_______________________________________________________________________________
|
||||
;
|
||||
; Change Log:
|
||||
;_______________________________________________________________________________
|
||||
;
|
||||
; ToDo:
|
||||
; 1) Add option to wait/prompt for disk change
|
||||
; 2) Allow <src> and <dest> to be memory
|
||||
;_______________________________________________________________________________
|
||||
;
|
||||
;===============================================================================
|
||||
; Definitions
|
||||
;===============================================================================
|
||||
;
|
||||
stksiz .equ $40 ; we are a stack pig
|
||||
;
|
||||
restart .equ $0000 ; CP/M restart vector
|
||||
bdos .equ $0005 ; BDOS invocation vector
|
||||
;
|
||||
buf .equ $900 ; load point for system image (from original SYSGEN)
|
||||
;
|
||||
;===============================================================================
|
||||
; Code Section
|
||||
;===============================================================================
|
||||
;
|
||||
.org $100
|
||||
; setup stack (save old value)
|
||||
ld (stksav),sp ; save stack
|
||||
ld sp,stack ; set new stack
|
||||
; processing...
|
||||
call main ; do the real work
|
||||
call crlf ; formatting
|
||||
; return
|
||||
jp 0 ; return to CP/M via reset
|
||||
;
|
||||
;ld sp,(stksav) ; restore stack
|
||||
;ret ; return to CP/M w/o reset
|
||||
;
|
||||
; Main routine
|
||||
;
|
||||
main:
|
||||
call init ; initialize
|
||||
ret nz ; abort on failure
|
||||
|
||||
call parse ; parse command tail
|
||||
ret nz ; abort on failure
|
||||
|
||||
call confirm ; confirm pending action
|
||||
ret nz ; abort on failure
|
||||
|
||||
call crlf ; formatting
|
||||
|
||||
ld de,msgrd
|
||||
call prtstr ; display "reading" message
|
||||
call rdimg ; do the image read
|
||||
ret nz ; abort on failure
|
||||
|
||||
ld de,msgwrt
|
||||
call prtstr ; display "writing" message
|
||||
call wrtimg ; do the image write
|
||||
ret nz ; abort on failure
|
||||
|
||||
ld de,msgdon ; completion message
|
||||
call prtstr ; display it
|
||||
|
||||
ret
|
||||
;
|
||||
; Initialization
|
||||
;
|
||||
init:
|
||||
; add check for RomWBW?
|
||||
;
|
||||
; locate cbios function table address
|
||||
ld hl,(restart+1) ; load address of CP/M restart vector
|
||||
ld de,-3 ; adjustment for start of table
|
||||
add hl,de ; HL now has start of table
|
||||
ld (cbftbl),hl ; save it
|
||||
; save current drive no
|
||||
ld c,$19 ; bdos func: get current drive
|
||||
call bdos ; invoke BDOS function
|
||||
inc a ; 1-based index for fcb
|
||||
ld (defdrv),a ; save it
|
||||
; return success
|
||||
xor a
|
||||
ret
|
||||
;
|
||||
; Parse command tail
|
||||
;
|
||||
parse:
|
||||
ld hl,$81 ; point to start of command tail (after length byte)
|
||||
call nonblank ; locate start of parms
|
||||
jp z,erruse ; no parms
|
||||
ld de,destfcb ; point to destination fcb
|
||||
call convert ; convert destination spec
|
||||
jp nz,erramb ; Error, ambiguous file specification
|
||||
call nonblank ; skip blanks
|
||||
or a ; end of command tail (null)?
|
||||
jr z,parse2 ; setup default source fcb
|
||||
cp '=' ; std delimiter
|
||||
jr z,parse1 ; valid delimiter, continue
|
||||
cp '_' ; alt delimiter
|
||||
jr z,parse1 ; valid delimiter, continue
|
||||
jp errdlm ; invalid delimiter
|
||||
parse1:
|
||||
inc hl ; skip delimiter
|
||||
call nonblank ; skip blanks
|
||||
parse2:
|
||||
ld de,srcfcb ; point to source fcb
|
||||
call convert ; convert spec to fcb
|
||||
jp nz,erramb ; Error, ambiguous file specification
|
||||
; return success
|
||||
xor a ; signal success
|
||||
ret ; done parsing
|
||||
;
|
||||
; Confirm pending action with user
|
||||
;
|
||||
confirm:
|
||||
; prompt
|
||||
call crlf
|
||||
ld de,sconf1
|
||||
call prtstr
|
||||
ld hl,srcfcb
|
||||
call prtfcb
|
||||
ld de,sconf2
|
||||
call prtstr
|
||||
ld hl,destfcb
|
||||
call prtfcb
|
||||
ld de,sconf3
|
||||
call prtstr
|
||||
;
|
||||
; get input
|
||||
ld c,$0A ; get console buffer
|
||||
ld de,buf ; into buf
|
||||
ld a,1 ; max of 1 character
|
||||
ld (de),a ; set up buffer
|
||||
call bdos ; invoke BDOS
|
||||
ld a,(buf+1) ; get num chars entered
|
||||
dec a ; check that we got exactly one char
|
||||
jr nz,confirm ; bad input, re-prompt
|
||||
ld a,(buf+2) ; get the character
|
||||
and $DF ; force upper case
|
||||
cp 'Y' ; compare to Y
|
||||
ret ; return with Z set appropriately
|
||||
;
|
||||
; Read system image
|
||||
;
|
||||
rdimg:
|
||||
ld hl,srcfcb ; point to source fcb
|
||||
call chkfcb ; check if for drive/file spec
|
||||
bit 1,a ; is there a file spec?
|
||||
jp nz,rdfil ; yes, read using file i/o
|
||||
jp rddsk ; no, read using raw disk i/o
|
||||
;
|
||||
; Write system image
|
||||
;
|
||||
wrtimg:
|
||||
ld hl,destfcb ; point to destination fcb
|
||||
call chkfcb ; check it for drive/file spec
|
||||
bit 1,a ; is there a file spec?
|
||||
jp nz,wrfil ; yes, write using file i/o
|
||||
jp wrdsk ; no, write using raw disk i/o
|
||||
|
||||
;
|
||||
; Read system image from file system
|
||||
;
|
||||
rdfil:
|
||||
; open the file
|
||||
ld c,$0F ; bdos open file
|
||||
ld de,srcfcb ; source fcb
|
||||
ld (rwfcb),de ; save it
|
||||
call bdos ; invoke bdos function
|
||||
cp $FF ; $FF is error
|
||||
jp z,errfil ; handle error condition
|
||||
; read the header
|
||||
ld a,$14 ; setup for bdos read sequential
|
||||
ld (rwfun),a ; save bdos function
|
||||
ld a,12 ; start with 1536 byte header (12 records)
|
||||
ld (reccnt),a ; init record counter
|
||||
ld hl,buf ; start of buffer
|
||||
ld (bufptr),hl ; init buffer pointer
|
||||
call rwfil ; read the header
|
||||
ret nz ; abort on error (no need to close file)
|
||||
; check header and get image size
|
||||
call chkhdr ; verifies marker & ver, hl = image size
|
||||
ret nz ; abort on error (no need to close file)
|
||||
ld b,7 ; right shift 7 bits to get 128 byte record count
|
||||
rdfil1: srl h ; shift right msb
|
||||
rr l ; shift lsb w/ carry from msb
|
||||
djnz rdfil1 ; loop till done
|
||||
ld a,l ; record count to a
|
||||
ld (reccnt),a ; set remaining records to read
|
||||
add a,12 ; add the header back
|
||||
ld (imgsiz),a ; and save the total image size (in records)
|
||||
call rwfil ; do it
|
||||
ret nz ; abort on error
|
||||
; return via close file
|
||||
jp closefile ; close file
|
||||
;
|
||||
; Write system image to file system
|
||||
;
|
||||
wrfil:
|
||||
; check for pre-existing target file
|
||||
ld c,$11 ; bdos find first
|
||||
ld de,destfcb ; destination fcb
|
||||
call bdos
|
||||
cp $FF ; check for error
|
||||
jr z,wrfil1 ; not there, skip delete
|
||||
; delete target file if it exists
|
||||
ld c,$13 ; bdos delete
|
||||
ld de,destfcb ; destination fcb
|
||||
call bdos
|
||||
cp $FF ; check return code
|
||||
jp z,errdel ; handle error
|
||||
wrfil1: ; create target file
|
||||
ld c,$16 ; bdos create file
|
||||
ld de,destfcb ; destination fcb
|
||||
ld (rwfcb),de ; save it
|
||||
call bdos
|
||||
cp $FF ; check return code
|
||||
jp z,errfil ; handle error
|
||||
; write the image
|
||||
ld a,$15 ; setup for bdos write sequential
|
||||
ld (rwfun),a ; save bdos function
|
||||
ld a,(imgsiz) ; number of records to read
|
||||
ld (reccnt),a ; init record counter
|
||||
ld hl,buf ; start of buffer
|
||||
ld (bufptr),hl ; init buffer pointer
|
||||
call rwfil ; do it
|
||||
ret nz ; abort on error
|
||||
; return via close file
|
||||
jp closefile ; close file
|
||||
;
|
||||
; Common routine to handle read/write for file system
|
||||
;
|
||||
rwfil:
|
||||
ld c,$1A ; BDOS set dma
|
||||
ld de,(bufptr) ; current buffer pointer
|
||||
push de ; save pointer
|
||||
call bdos ; do it
|
||||
pop de ; recover pointer
|
||||
ld hl,128 ; record length
|
||||
add hl,de ; increment buffer pointer
|
||||
ld (bufptr),hl ; save it
|
||||
ld a,(rwfun) ; get the active function
|
||||
ld c,a ; set it
|
||||
ld de,(rwfcb) ; active fcb
|
||||
call bdos ; do it
|
||||
or a ; check return code
|
||||
jp nz,errdos ; BDOS err
|
||||
ld hl,reccnt ; point to record count
|
||||
dec (hl) ; decrement record count
|
||||
jr nz,rwfil ; loop till done
|
||||
xor a ; signal success
|
||||
ret ; done
|
||||
;
|
||||
; Close file
|
||||
;
|
||||
closefile:
|
||||
ld c,$10 ; BDOS close file
|
||||
ld de,(rwfcb) ; active fcb
|
||||
call bdos ; do it
|
||||
cp $FF ; $FF is error
|
||||
jp z,errclo ; if error, handle it
|
||||
xor a ; signal success
|
||||
ret ; done
|
||||
;
|
||||
; Read image directly from disk system tracks using CBIOS
|
||||
;
|
||||
rddsk:
|
||||
; force return to go through disk reset
|
||||
ld hl,resdsk ; load address of reset disk routine
|
||||
push hl ; and put it on the stack
|
||||
; set drive for subsequent reads
|
||||
ld a,(srcfcb) ; get the drive
|
||||
dec a ; adjust for zero indexing
|
||||
call setdsk ; setup disk
|
||||
ret nz ; abort on error
|
||||
; set function to read
|
||||
ld hl,(cbftbl) ; get address of CBIOS function table
|
||||
ld a,$27 ; $27 is CBIOS READ entry offset
|
||||
call addhl ; set HL to resultant entry point
|
||||
ld (actfnc),hl ; save it
|
||||
; read the header
|
||||
ld a,12 ; start with 1536 byte header (12 records)
|
||||
ld (reccnt),a ; initialize record counter
|
||||
call rwdsk ; read the header
|
||||
ret nz ; abort on error
|
||||
; check header and get image size
|
||||
call chkhdr ; check integrity, HL = image size on return
|
||||
ret nz ; abort on error
|
||||
; convert image size to count of 128-byte records
|
||||
ld b,7 ; right shift 7 bits to get 128 byte record count
|
||||
rddsk1: srl h ; shift right msb
|
||||
rr l ; shift lsb w/ carry from msb
|
||||
djnz rddsk1 ; loop till done
|
||||
; set the number of records pending to read
|
||||
ld a,l ; record count to a
|
||||
ld (reccnt),a ; set remaining records to read
|
||||
; save the total image size (including header) for later
|
||||
add a,12 ; add the header records back
|
||||
ld (imgsiz),a ; and save the total image size (in records)
|
||||
; read the remaining system image records
|
||||
call rwdsk ; finish up
|
||||
ret nz ; abort on error
|
||||
; perform BDOS disk reset (critical since we mucked with CBIOS)
|
||||
ld c,$0D ; BDOS reset disk
|
||||
call bdos ; do it
|
||||
; return
|
||||
xor a ; signal success
|
||||
ret ; done
|
||||
;
|
||||
; Write image directly to disk system tracks using CBIOS
|
||||
;
|
||||
wrdsk:
|
||||
; force return to go through disk reset
|
||||
ld hl,resdsk ; load address of reset disk routine
|
||||
push hl ; and put it on the stack
|
||||
; set drive for subsequent writes
|
||||
ld a,(destfcb) ; get the drive
|
||||
dec a ; adjust for zero indexing
|
||||
call setdsk ; setup disk
|
||||
ret nz ; abort on error
|
||||
; set function to write
|
||||
ld hl,(cbftbl) ; get address of CBIOS function table
|
||||
ld a,$2A ; $2A is CBIOS WRITE entry offset
|
||||
call addhl ; set HL to resultant entry point
|
||||
ld (actfnc),hl ; save it
|
||||
; setup the record count to write
|
||||
ld a,(imgsiz) ; get previously recorded image size
|
||||
ld (reccnt),a ; save it as pending record count
|
||||
; write the image
|
||||
call rwdsk ; write the image
|
||||
ret nz ; abort on error
|
||||
; return
|
||||
xor a ; signal success
|
||||
ret ; done
|
||||
;
|
||||
; Perform BDOS disk reset
|
||||
; Required after making direct CBIOS disk calls
|
||||
;
|
||||
resdsk:
|
||||
; perform BDOS disk reset
|
||||
push af ; preserve status
|
||||
ld c,$0D ; BDOS reset disk
|
||||
call bdos ; do it
|
||||
pop af ; restore status
|
||||
ret
|
||||
;
|
||||
; Setup for CBIOS disk access
|
||||
;
|
||||
setdsk:
|
||||
; select disk
|
||||
ld (actdsk),a ; save active disk no
|
||||
ld c,a ; move to c
|
||||
ld e,0 ; treat as first select
|
||||
call cbios ; invoke cbios with...
|
||||
.db $1B ; SELDSK entry offset
|
||||
; check return (sets HL to DPH address)
|
||||
ld a,h
|
||||
or l
|
||||
jp z,errsel ; HL == 0 is select error
|
||||
; set HL to DPB address
|
||||
ld de,10 ; DPB address is 10 bytes into DPH
|
||||
add hl,de ; HL := address of DPB pointer
|
||||
ld a,(hl) ; dereference...
|
||||
inc hl
|
||||
ld h,(hl)
|
||||
ld l,a ; HL := address of DPB
|
||||
; extract sectors per track from first word of DPB
|
||||
ld c,(hl)
|
||||
inc hl
|
||||
ld b,(hl) ; BC := sectors per track
|
||||
ld (actspt),bc ; save it
|
||||
; ensure there are system tracks (verify that offset field in DPB is not zero)
|
||||
ld de,12 ; offset field is 12 bytes into DPB
|
||||
add hl,de ; point to offset field in DPB
|
||||
ld a,(hl) ; load first byte in A
|
||||
inc hl ; point to second byte
|
||||
or (hl) ; or with first byte
|
||||
jp z,errsys ; if zero, abort (no system tracks)
|
||||
; initialize for I/O
|
||||
ld hl,0
|
||||
ld (acttrk),hl ; active track := 0
|
||||
ld (actsec),hl ; active sector := 0
|
||||
ld hl,buf
|
||||
ld (bufptr),hl ; reset buffer pointer
|
||||
;
|
||||
xor a ; signal success
|
||||
ret ; done
|
||||
;
|
||||
; Read or write (reccnt) sectors to/from disk via CBIOS
|
||||
;
|
||||
rwdsk:
|
||||
; setup to read/write a sector
|
||||
ld bc,(acttrk) ; get active track
|
||||
call cbios ; invoke cbios with...
|
||||
.db $1E ; SETTRK entry offset
|
||||
ld bc,(actsec) ; get active sector
|
||||
call cbios ; invoke cbios with...
|
||||
.db $21 ; SETSEC entry offset
|
||||
ld bc,(bufptr) ; get active buffer pointer
|
||||
call cbios ; invoke cbios with...
|
||||
.db $24 ; SETDMA entry offset
|
||||
; read/write sector
|
||||
ld a,(reccnt) ; get the pending record count
|
||||
dec a ; last record?
|
||||
ld c,2 ; allow cached writes by default
|
||||
jr nz,rwdsk1 ; not last record, continue
|
||||
ld c,1 ; last record, no caching please
|
||||
rwdsk1: ld hl,(actfnc) ; load the CBIOS function vector
|
||||
call jphl ; indirect call (read or write)
|
||||
or a ; set flags on return code
|
||||
jp nz,errio ; if not zero, error abort
|
||||
; adjust buffer pointer
|
||||
ld hl,(bufptr) ; get buffer pointer
|
||||
ld de,128 ; record length is 128 bytes
|
||||
add hl,de ; adjust buffer ptr for next record
|
||||
ld (bufptr),hl ; save it
|
||||
; next sector
|
||||
ld hl,(actsec) ; current sector
|
||||
inc hl ; increment sector
|
||||
ld (actsec),hl ; save it
|
||||
; check for end of track
|
||||
ld de,(actspt) ; get current sectors per track
|
||||
or a ; clear CF
|
||||
sbc hl,de ; current track == sectors per track?
|
||||
jr nz,rwdsk2 ; no, skip track change
|
||||
; next track
|
||||
ld hl,0
|
||||
ld (actsec),hl ; current sector := 0
|
||||
ld hl,acttrk ; point to track variable
|
||||
inc (hl) ; increment track
|
||||
; check pending record count and loop or return
|
||||
rwdsk2: ld hl,reccnt
|
||||
dec (hl) ; decrement pending record count
|
||||
ret z ; if zero, done, return with Z set
|
||||
jr rwdsk ; otherwise, loop
|
||||
;
|
||||
jphl: jp (hl) ; indirect jump
|
||||
;
|
||||
; Verify system image header in buf by checking the expected signature.
|
||||
; Compute and return image size (based on header values) in HL.
|
||||
; NZ set if signature error.
|
||||
;
|
||||
chkhdr:
|
||||
; check signature
|
||||
ld hl,(buf+$580) ; get signature
|
||||
ld de,$A55A ; signature value
|
||||
or a ; clear CF
|
||||
sbc hl,de ; compare
|
||||
jp nz,errsig ; invalid signature
|
||||
; compute the image size (does not include size of header)
|
||||
ld hl,(buf+$5FC) ; get CPM_END
|
||||
ld de,(buf+$5FA) ; get CPM_LOC
|
||||
or a ; clear CF
|
||||
sbc hl,de ; image size := CPM_END - CPM_LOC
|
||||
xor a ; signal success
|
||||
ret ; done
|
||||
;
|
||||
; Convert a filename at (HL) into an FCB at (DE).
|
||||
; Includes wildcard expansion.
|
||||
; On return, A=0 if unambiguous name specified, and
|
||||
; (HL) points to character following filename spec
|
||||
;
|
||||
convert:
|
||||
push de ; put fcb address on stack
|
||||
ex de,hl
|
||||
ld a,(de) ; get first character.
|
||||
or a
|
||||
jp z,convrt1
|
||||
sbc a,'A'-1 ; might be a drive name, convert to binary.
|
||||
ld b,a ; and save.
|
||||
inc de ; check next character for a ':'.
|
||||
ld a,(de)
|
||||
cp ':'
|
||||
jp z,convrt2
|
||||
dec de ; nope, move pointer back to the start of the line.
|
||||
convrt1:
|
||||
ld a,(defdrv)
|
||||
ld (hl),a
|
||||
jp convrt3
|
||||
convrt2:
|
||||
ld a,b
|
||||
ld (hl),b
|
||||
inc de
|
||||
; Convert the base file name.
|
||||
convrt3:ld b,08h
|
||||
convrt4:ld a,(de)
|
||||
call delim
|
||||
jp z,convrt8
|
||||
inc hl
|
||||
cp '*' ; note that an '*' will fill the remaining
|
||||
jp nz,convrt5 ; field with '?'
|
||||
ld (hl),'?'
|
||||
jp convrt6
|
||||
convrt5:ld (hl),a
|
||||
inc de
|
||||
convrt6:dec b
|
||||
jp nz,convrt4
|
||||
convrt7:ld a,(de)
|
||||
call delim ; get next delimiter
|
||||
jp z,getext
|
||||
inc de
|
||||
jp convrt7
|
||||
convrt8:inc hl ; blank fill the file name
|
||||
ld (hl),' '
|
||||
dec b
|
||||
jp nz,convrt8
|
||||
getext: ld b,03h
|
||||
cp '.'
|
||||
jp nz,getext5
|
||||
inc de
|
||||
getext1:ld a,(de)
|
||||
call delim
|
||||
jp z,getext5
|
||||
inc hl
|
||||
cp '*'
|
||||
jp nz,getext2
|
||||
ld (hl),'?'
|
||||
jp getext3
|
||||
getext2:ld (hl),a
|
||||
inc de
|
||||
getext3:dec b
|
||||
jp nz,getext1
|
||||
getext4:ld a,(de)
|
||||
call delim
|
||||
jp z,getext6
|
||||
inc de
|
||||
jp getext4
|
||||
getext5:inc hl
|
||||
ld (hl),' '
|
||||
dec b
|
||||
jp nz,getext5
|
||||
getext6:ld b,3
|
||||
getext7:inc hl
|
||||
ld (hl),0
|
||||
dec b
|
||||
jp nz,getext7
|
||||
pop hl ; HL := start of FCB
|
||||
push de ; save input line pointer
|
||||
; Check to see if this is an ambiguous file name specification.
|
||||
; Set the A register to non-zero if it is.
|
||||
ld bc,11 ; set name length.
|
||||
getext8:inc hl
|
||||
ld a,(hl)
|
||||
cp '?' ; any question marks?
|
||||
jp nz,getext9
|
||||
inc b ; count them.
|
||||
getext9:dec c
|
||||
jp nz,getext8
|
||||
ld a,b
|
||||
or a
|
||||
pop hl ; return with updated input pointer
|
||||
ret
|
||||
;
|
||||
; Print formatted FCB at (HL)
|
||||
;
|
||||
prtfcb:
|
||||
push hl ; save HL
|
||||
call chkfcb ; set flags indicating nature of FCB
|
||||
pop hl ; restore HL
|
||||
ret z ; nothing to print
|
||||
push af ; save FCB flags
|
||||
ld a,(hl) ; get first byte of FCB (drive)
|
||||
inc hl ; point to next char
|
||||
or a ; is drive specified (non-zero)?
|
||||
jr z,prtfcb1 ; if zero, do not print drive letter
|
||||
add a,'@' ; adjust drive number to alpha
|
||||
call prtchr ; print it
|
||||
ld a,':'
|
||||
call prtchr ; print drive separator
|
||||
prtfcb1:
|
||||
pop af ; restore FCB flags
|
||||
bit 1,a ; bit 1 set if filename specified
|
||||
ret z ; return if no filename
|
||||
ld b,8 ; base is 8 characters
|
||||
call prtfcb2 ; print them
|
||||
ld a,'.'
|
||||
call prtchr ; print file extension separator
|
||||
ld b,3 ; extension is 3 characters
|
||||
prtfcb2:
|
||||
ld a,(hl) ; load the next character
|
||||
inc hl ; point to next character
|
||||
cp ' ' ; check for blank
|
||||
call nz,prtchr ; print char if it is not a blank
|
||||
djnz prtfcb2 ; loop till done
|
||||
ret ; return
|
||||
;
|
||||
; Check FCB to see if a drive and/or filename is specified.
|
||||
; Set bit 0 for drive and bit 1 for filename in A
|
||||
;
|
||||
chkfcb:
|
||||
ld c,0 ; use C for flags, start with none
|
||||
ld a,(hl) ; get drive
|
||||
or a ; anything there?
|
||||
jr z,chkfcb1 ; skip if nothing there
|
||||
set 0,c ; set bit zero to indicate a drive spec
|
||||
chkfcb1:
|
||||
ld b,11 ; set up to check 11 bytes (base & ext)
|
||||
chkfcb2:
|
||||
inc hl ; bump to next byte
|
||||
ld a,(hl) ; get next
|
||||
cp 'A' ; blank means empty byte
|
||||
jr nc,chkfcb3 ; if not blank, we have a filename
|
||||
djnz chkfcb2 ; loop
|
||||
jr chkfcb4 ; nothing there
|
||||
chkfcb3:
|
||||
set 1,c ; set bit 1 to indicate a file spec
|
||||
chkfcb4:
|
||||
ld a,c ; put result in a
|
||||
or a ; set flags
|
||||
ret
|
||||
;
|
||||
; Print character in A without destroying any registers
|
||||
;
|
||||
prtchr:
|
||||
push bc ; save registers
|
||||
push de
|
||||
push hl
|
||||
ld e,a ; character to print in E
|
||||
ld c,$02 ; BDOS function to output a character
|
||||
call bdos ; do it
|
||||
pop hl ; restore registers
|
||||
pop de
|
||||
pop bc
|
||||
ret
|
||||
;
|
||||
; Print $ terminated string at (DE) without destroying any registers
|
||||
;
|
||||
prtstr:
|
||||
push bc ; save registers
|
||||
push de
|
||||
push hl
|
||||
ld c,$09 ; BDOS function to output a '$' terminated string
|
||||
call bdos ; do it
|
||||
pop hl ; restore registers
|
||||
pop de
|
||||
pop bc
|
||||
ret
|
||||
;
|
||||
; Print the value in A in hex without destroying any registers
|
||||
;
|
||||
prthex:
|
||||
push af ; save AF
|
||||
push de ; save DE
|
||||
call hexascii ; convert value in A to hex chars in DE
|
||||
ld a,d ; get the high order hex char
|
||||
call prtchr ; print it
|
||||
ld a,e ; get the low order hex char
|
||||
call prtchr ; print it
|
||||
pop de ; restore DE
|
||||
pop af ; restore AF
|
||||
ret ; done
|
||||
;
|
||||
; Convert binary value in A to ascii hex characters in DE
|
||||
;
|
||||
hexascii:
|
||||
ld d,a ; save A in D
|
||||
call hexconv ; convert low nibble of A to hex
|
||||
ld e,a ; save it in E
|
||||
ld a,d ; get original value back
|
||||
rlca ; rotate high order nibble to low bits
|
||||
rlca
|
||||
rlca
|
||||
rlca
|
||||
call hexconv ; convert nibble
|
||||
ld d,a ; save it in D
|
||||
ret ; done
|
||||
;
|
||||
; Convert low nibble of A to ascii hex
|
||||
;
|
||||
hexconv:
|
||||
and $0F ; low nibble only
|
||||
add a,$90
|
||||
daa
|
||||
adc a,$40
|
||||
daa
|
||||
ret
|
||||
;
|
||||
; Start a new line
|
||||
;
|
||||
crlf:
|
||||
ld a,13 ; <CR>
|
||||
call prtchr ; print it
|
||||
ld a,10 ; <LF>
|
||||
jr prtchr ; print it
|
||||
;
|
||||
; Get the next non-blank character from (HL).
|
||||
;
|
||||
nonblank:
|
||||
ld a,(hl) ; load next character
|
||||
or a ; string ends with a null
|
||||
ret z ; if null, return pointing to null
|
||||
cp ' ' ; check for blank
|
||||
ret nz ; return if not blank
|
||||
inc hl ; if blank, increment character pointer
|
||||
jr nonblank ; and loop
|
||||
;
|
||||
; Check character at (DE) for delimiter.
|
||||
;
|
||||
delim: or a
|
||||
ret z
|
||||
cp ' ' ; blank
|
||||
ret z
|
||||
jr c,delim1 ; handle control characters
|
||||
cp '=' ; equal
|
||||
ret z
|
||||
cp '_' ; underscore
|
||||
ret z
|
||||
cp '.' ; period
|
||||
ret z
|
||||
cp ':' ; colon
|
||||
ret z
|
||||
cp $3b ; semicolon
|
||||
ret z
|
||||
cp '<' ; less than
|
||||
ret z
|
||||
cp '>' ; greater than
|
||||
ret
|
||||
delim1:
|
||||
; treat control chars as delimiters
|
||||
xor a ; set Z
|
||||
ret ; return
|
||||
;
|
||||
; Invoke CBIOS function
|
||||
; The CBIOS function offset must be stored in the byte
|
||||
; following the call instruction. ex:
|
||||
; call cbios
|
||||
; .db $0C ; offset of CONOUT CBIOS function
|
||||
;
|
||||
cbios:
|
||||
ex (sp),hl
|
||||
ld a,(hl) ; get the function offset
|
||||
inc hl ; point past value following call instruction
|
||||
ex (sp),hl ; put address back at top of stack and recover HL
|
||||
ld hl,(cbftbl) ; address of CBIOS function table to HL
|
||||
call addhl ; determine specific function address
|
||||
jp (hl) ; invoke CBIOS
|
||||
;
|
||||
; Add the value in A to HL (HL := HL + A)
|
||||
;
|
||||
addhl:
|
||||
add a,l ; A := A + L
|
||||
ld l,a ; Put result back in L
|
||||
ret nc ; if no carry, we are done
|
||||
inc h ; if carry, increment H
|
||||
ret ; and return
|
||||
;
|
||||
; Errors
|
||||
;
|
||||
erruse: ; command usage error (syntax)
|
||||
ld de,msguse
|
||||
jr err
|
||||
erramb: ; ambiguous file spec (wild cards) is not allowed
|
||||
ld de,msgamb
|
||||
jr err
|
||||
errdlm: ; invalid delimiter in command tail
|
||||
ld de,msgdlm
|
||||
jr err
|
||||
errfil: ; source file not found
|
||||
ld de,msgfil
|
||||
jr err
|
||||
errclo: ; file close error
|
||||
ld de,msgclo
|
||||
jr err
|
||||
errdel: ; file delete error
|
||||
ld de,msgdel
|
||||
jr err
|
||||
errsig: ; invalid system image signature error
|
||||
ld de,msgsig
|
||||
jr err
|
||||
errsel: ; CBIOS drive select error
|
||||
ld de,msgsel
|
||||
jr err
|
||||
errsys: ; no system tracks on drive error
|
||||
ld de,msgsys
|
||||
jr err
|
||||
errio: ; I/O error
|
||||
ld de,msgio
|
||||
jr err
|
||||
err: ; print error string and return error signal
|
||||
call crlf ; print newline
|
||||
call prtstr ; print error string
|
||||
or $FF ; signal error
|
||||
ret ; done
|
||||
errdos: ; handle BDOS errors
|
||||
push af ; save return code
|
||||
call crlf ; newline
|
||||
ld de,msgdos ; load
|
||||
call prtstr ; and print error string
|
||||
pop af ; recover return code
|
||||
call prthex ; print error code
|
||||
or $FF ; signal error
|
||||
ret ; done
|
||||
;
|
||||
;===============================================================================
|
||||
; Storage Section
|
||||
;===============================================================================
|
||||
;
|
||||
defdrv .db 0 ; default drive for FCB
|
||||
cbftbl .dw 0 ; address of CBIOS function table
|
||||
imgsiz .db 0 ; image size (count of 128 byte records)
|
||||
;
|
||||
destfcb .fill 36,0 ; destination FCB
|
||||
srcfcb .fill 36,0 ; source FCB
|
||||
;
|
||||
stksav .dw 0 ; stack pointer saved at start
|
||||
.fill stksiz,0 ; stack
|
||||
stack .equ $ ; stack top
|
||||
;
|
||||
rwfun .db 0 ; active read/write function
|
||||
rwfcb .dw 0 ; active read/write FCB
|
||||
reccnt .db 0 ; active remaining records to read/write
|
||||
bufptr .dw 0 ; active pointer into buffer
|
||||
;
|
||||
actdsk .db 0 ; active disk no
|
||||
acttrk .dw 0 ; active track
|
||||
actsec .dw 0 ; active sector
|
||||
actspt .dw 0 ; active sectors per track
|
||||
actfnc .dw 0 ; active function (read or write)
|
||||
;
|
||||
; Messages
|
||||
;
|
||||
msguse .db "Usage: SYSCOPY <dest>[=<source>]$"
|
||||
msgamb .db "Ambiguous file specification not allowed$"
|
||||
msgdlm .db "Invalid delimiter$"
|
||||
msgfil .db "File not found$"
|
||||
msgclo .db "File close error$"
|
||||
msgdel .db "Error deleting target file$"
|
||||
msgsig .db "Invalid system image (bad signature)$"
|
||||
msgdos .db "DOS error, return code=0x$"
|
||||
msgsel .db "Disk select error$"
|
||||
msgsys .db "Non-system disk error$"
|
||||
msgio .db "Disk I/O error$"
|
||||
msgrd .db "Reading image... $"
|
||||
msgwrt .db "Writing image... $"
|
||||
msgdon .db "Done$"
|
||||
sconf1 .db "Transfer system image from $"
|
||||
sconf2 .db " to $"
|
||||
sconf3 .db " (Y/N)? $"
|
||||
;
|
||||
.end
|
||||
507
Apps/SysGen.z80
507
Apps/SysGen.z80
@@ -1,507 +0,0 @@
|
||||
TITLE 'SYSGEN - SYSTEM GENERATION PROGRAM 8/79'
|
||||
; SYSTEM GENERATION PROGRAM, VERSION FOR ROMWBW
|
||||
VERS EQU 20 ; X.X
|
||||
;
|
||||
; COPYRIGHT (C) DIGITAL RESEARCH
|
||||
; 1976, 1977, 1978, 1979
|
||||
;
|
||||
NDISKS EQU 16 ; NUMBER OF DISK DRIVES
|
||||
SECSIZ EQU 128 ; SIZE OF EACH SECTOR
|
||||
LOG2SEC EQU 7 ; LOG 2 SECSIZ
|
||||
;
|
||||
FCB EQU 05CH ; DEFAULT FCB LOCATION
|
||||
FCBCR EQU FCB+32 ; CURRENT RECORD LOCATION
|
||||
TPA EQU 0100H ; TRANSIENT PROGRAM AREA
|
||||
LOADP EQU 900H ; LOAD POINT FOR SYSTEM DURING LOAD/STORE
|
||||
BDOS EQU 5 ; DOS ENTRY POINT
|
||||
BOOT EQU 0 ; JMP TO 'BOOT' TO REBOOT SYSTEM
|
||||
CONI EQU 1 ; CONSOLE INPUT FUNCTION
|
||||
CONO EQU 2 ; CONSOLE OUTPUT FUNCTION
|
||||
OPENF EQU 15 ; DISK OPEN FUNCTION
|
||||
DREADF EQU 20 ; DISK READ FUNCTION
|
||||
;
|
||||
CR EQU 0DH ; CARRIAGE RETURN
|
||||
LF EQU 0AH ; LINE FEED
|
||||
STKSIZE EQU 16 ; SIZE OF LOCAL STACK
|
||||
;
|
||||
WBOOT EQU 1 ; ADDRESS OF WARM BOOT (OTHER PATCH ENTRY
|
||||
;
|
||||
ORG TPA ; TRANSIENT PROGRAM AREA
|
||||
JP START
|
||||
DB 'COPYRIGHT (C) 1978, DIGITAL RESEARCH '
|
||||
;
|
||||
; UTILITY SUBROUTINES
|
||||
;
|
||||
GETCHAR:
|
||||
; READ CONSOLE CHARACTER TO REGISTER A
|
||||
LD C,CONI
|
||||
CALL BDOS
|
||||
; CONVERT TO UPPER CASE BEFORE RETURN
|
||||
CP 'A' OR 20H
|
||||
RET C ; RETURN IF BELOW LOWER CASE A
|
||||
CP ('Z' OR 20H) + 1
|
||||
RET NC ; RETURN IF ABOVE LOWER CASE Z
|
||||
AND 5FH
|
||||
RET
|
||||
;
|
||||
PUTCHAR:
|
||||
; WRITE CHARACTER FROM A TO CONSOLE
|
||||
LD E,A
|
||||
LD C,CONO
|
||||
CALL BDOS
|
||||
RET
|
||||
;
|
||||
CRLF: ; SEND CARRIAGE RETURN, LINE FEED
|
||||
LD A,CR
|
||||
CALL PUTCHAR
|
||||
LD A,LF
|
||||
CALL PUTCHAR
|
||||
RET
|
||||
;
|
||||
CRMSG: ; PRINT MESSAGE ADDRESSED BY H,L TIL ZERO
|
||||
; WITH LEADING CRLF
|
||||
PUSH HL
|
||||
CALL CRLF
|
||||
POP HL ; DROP THRU TO OUTMSG0
|
||||
OUTMSG:
|
||||
LD A,(HL)
|
||||
OR A
|
||||
RET Z
|
||||
; MESSAGE NOT YET COMPLETED
|
||||
PUSH HL
|
||||
CALL PUTCHAR
|
||||
POP HL
|
||||
INC HL
|
||||
JP OUTMSG
|
||||
;
|
||||
DREAD: ; DISK READ FUNCTION VIA BDOS
|
||||
LD C,DREADF
|
||||
JP BDOS
|
||||
;
|
||||
OPEN: ; FILE OPEN FUNCTION VIA BDOS
|
||||
LD C,OPENF
|
||||
JP BDOS
|
||||
;
|
||||
; READ IMAGE DIRECTLY FROM DISK SYSTEM TRACKS USING CBIOS
|
||||
; DISK NUMBER MUST BE IN (ACTDSK)
|
||||
;
|
||||
RDDSK:
|
||||
; FORCE RETURN TO GO THROUGH DISK RESET
|
||||
LD HL,RESDSK ; LOAD ADDRESS OF RESET DISK ROUTINE
|
||||
PUSH HL ; AND PUT IT ON THE STACK
|
||||
; SET DRIVE FOR SUBSEQUENT READS
|
||||
CALL SETDSK ; SETUP DISK SPECIFIED IN A
|
||||
RET NZ ; ABORT ON ERROR
|
||||
; SET FUNCTION TO READ
|
||||
LD HL,(CBFTBL) ; GET ADDRESS OF CBIOS FUNCTION TABLE
|
||||
LD A,027H ; $27 IS CBIOS READ ENTRY OFFSET
|
||||
CALL ADDHL ; SET HL TO RESULTANT ENTRY POINT
|
||||
LD (ACTFNC),HL ; SAVE IT
|
||||
; READ THE HEADER
|
||||
LD A,12 ; START WITH 1536 BYTE HEADER (12 RECORDS)
|
||||
LD (RECCNT),A ; INITIALIZE RECORD COUNTER
|
||||
CALL RWDSK ; READ THE HEADER
|
||||
RET NZ ; ABORT ON ERROR
|
||||
; CHECK HEADER AND GET IMAGE SIZE
|
||||
CALL CHKHDR ; CHECK INTEGRITY, HL = IMAGE SIZE ON RETURN
|
||||
RET NZ ; ABORT ON ERROR
|
||||
; CONVERT IMAGE SIZE TO COUNT OF 128-BYTE RECORDS
|
||||
LD B,7 ; RIGHT SHIFT 7 BITS TO GET 128 BYTE RECORD COUNT
|
||||
RDDSK1: SRL H ; SHIFT RIGHT MSB
|
||||
RR L ; SHIFT LSB W/ CARRY FROM MSB
|
||||
DJNZ RDDSK1 ; LOOP TILL DONE
|
||||
; SET THE NUMBER OF RECORDS PENDING TO READ
|
||||
LD A,L ; RECORD COUNT TO A
|
||||
LD (RECCNT),A ; SET REMAINING RECORDS TO READ
|
||||
; SAVE THE TOTAL IMAGE SIZE (INCLUDING HEADER) FOR LATER
|
||||
ADD A,12 ; ADD THE HEADER RECORDS BACK
|
||||
LD (IMGSIZ),A ; AND SAVE THE TOTAL IMAGE SIZE (IN RECORDS)
|
||||
; READ THE REMAINING SYSTEM IMAGE RECORDS
|
||||
CALL RWDSK ; FINISH UP
|
||||
RET NZ ; ABORT ON ERROR
|
||||
; PERFORM BDOS DISK RESET (CRITICAL SINCE WE MUCKED WITH CBIOS)
|
||||
LD C,0DH ; BDOS RESET DISK
|
||||
CALL BDOS ; DO IT
|
||||
; RETURN
|
||||
XOR A ; SIGNAL SUCCESS
|
||||
RET ; DONE
|
||||
;
|
||||
; WRITE IMAGE DIRECTLY TO DISK SYSTEM TRACKS USING CBIOS
|
||||
; DISK NUMBER MUST BE IN (ACTDSK)
|
||||
;
|
||||
WRDSK:
|
||||
; FORCE RETURN TO GO THROUGH DISK RESET
|
||||
LD HL,RESDSK ; LOAD ADDRESS OF RESET DISK ROUTINE
|
||||
PUSH HL ; AND PUT IT ON THE STACK
|
||||
; SET DRIVE FOR SUBSEQUENT WRITES
|
||||
CALL SETDSK ; SETUP DISK SPECIFIED IN A
|
||||
RET NZ ; ABORT ON ERROR
|
||||
; SET FUNCTION TO WRITE
|
||||
LD HL,(CBFTBL) ; GET ADDRESS OF CBIOS FUNCTION TABLE
|
||||
LD A,02AH ; $2A IS CBIOS WRITE ENTRY OFFSET
|
||||
CALL ADDHL ; SET HL TO RESULTANT ENTRY POINT
|
||||
LD (ACTFNC),HL ; SAVE IT
|
||||
; SETUP THE RECORD COUNT TO WRITE
|
||||
LD A,(IMGSIZ) ; GET PREVIOUSLY RECORDED IMAGE SIZE
|
||||
LD (RECCNT),A ; SAVE IT AS PENDING RECORD COUNT
|
||||
; WRITE THE IMAGE
|
||||
CALL RWDSK ; WRITE THE IMAGE
|
||||
RET NZ ; ABORT ON ERROR
|
||||
; RETURN
|
||||
XOR A ; SIGNAL SUCCESS
|
||||
RET ; DONE
|
||||
;
|
||||
; PERFORM BDOS DISK RESET
|
||||
; REQUIRED AFTER MAKING DIRECT CBIOS DISK CALLS
|
||||
;
|
||||
RESDSK:
|
||||
; PERFORM BDOS DISK RESET
|
||||
PUSH AF ; PRESERVE STATUS
|
||||
LD C,0DH ; BDOS RESET DISK
|
||||
CALL BDOS ; DO IT
|
||||
POP AF ; RESTORE STATUS
|
||||
RET
|
||||
;
|
||||
; SETUP FOR CBIOS DISK ACCESS
|
||||
;
|
||||
SETDSK:
|
||||
; SELECT DISK
|
||||
LD A,(ACTDSK) ; GET ACTIVE DISK
|
||||
LD C,A ; MOVE TO C
|
||||
LD E,0 ; TREAT AS FIRST SELECT
|
||||
CALL CBIOS ; INVOKE CBIOS WITH...
|
||||
DB 01BH ; SELDSK ENTRY OFFSET
|
||||
; CHECK RETURN (SETS HL TO DPH ADDRESS)
|
||||
LD A,H
|
||||
OR L
|
||||
JP Z,ERRSEL ; HL == 0 IS SELECT ERROR
|
||||
; SET HL TO DPB ADDRESS
|
||||
LD DE,10 ; DPB ADDRESS IS 10 BYTES INTO DPH
|
||||
ADD HL,DE ; HL := ADDRESS OF DPB POINTER
|
||||
LD A,(HL) ; DEREFERENCE...
|
||||
INC HL
|
||||
LD H,(HL)
|
||||
LD L,A ; HL := ADDRESS OF DPB
|
||||
; EXTRACT SECTORS PER TRACK FROM FIRST WORD OF DPB
|
||||
LD C,(HL)
|
||||
INC HL
|
||||
LD B,(HL) ; BC := SECTORS PER TRACK
|
||||
LD (ACTSPT),BC ; SAVE IT
|
||||
; ENSURE THERE ARE SYSTEM TRACKS (VERIFY THAT OFFSET FIELD IN DPB IS NOT ZERO)
|
||||
LD DE,12 ; OFFSET FIELD IS 12 BYTES INTO DPB
|
||||
ADD HL,DE ; POINT TO OFFSET FIELD IN DPB
|
||||
LD A,(HL) ; LOAD FIRST BYTE IN A
|
||||
INC HL ; POINT TO SECOND BYTE
|
||||
OR (HL) ; OR WITH FIRST BYTE
|
||||
JP Z,ERRSYS ; IF ZERO, ABORT (NO SYSTEM TRACKS)
|
||||
; INITIALIZE FOR I/O
|
||||
LD HL,0
|
||||
LD (ACTTRK),HL ; ACTIVE TRACK := 0
|
||||
LD (ACTSEC),HL ; ACTIVE SECTOR := 0
|
||||
LD HL,LOADP
|
||||
LD (BUFPTR),HL ; RESET BUFFER POINTER
|
||||
;
|
||||
XOR A ; SIGNAL SUCCESS
|
||||
RET ; DONE
|
||||
;
|
||||
; READ OR WRITE (RECCNT) SECTORS TO/FROM DISK VIA CBIOS
|
||||
;
|
||||
RWDSK:
|
||||
; SETUP TO READ/WRITE A SECTOR
|
||||
LD BC,(ACTTRK) ; GET ACTIVE TRACK
|
||||
CALL CBIOS ; INVOKE CBIOS WITH...
|
||||
DB 01EH ; SETTRK ENTRY OFFSET
|
||||
LD BC,(ACTSEC) ; GET ACTIVE SECTOR
|
||||
CALL CBIOS ; INVOKE CBIOS WITH...
|
||||
DB 021H ; SETSEC ENTRY OFFSET
|
||||
LD BC,(BUFPTR) ; GET ACTIVE BUFFER POINTER
|
||||
CALL CBIOS ; INVOKE CBIOS WITH...
|
||||
DB 024H ; SETDMA ENTRY OFFSET
|
||||
; READ/WRITE SECTOR
|
||||
LD A,(RECCNT) ; GET THE PENDING RECORD COUNT
|
||||
DEC A ; LAST RECORD?
|
||||
LD C,2 ; ALLOW CACHED WRITES BY DEFAULT
|
||||
JR NZ,RWDSK1 ; NOT LAST RECORD, CONTINUE
|
||||
LD C,1 ; LAST RECORD, NO CACHING PLEASE
|
||||
RWDSK1: LD HL,(ACTFNC) ; LOAD THE CBIOS FUNCTION VECTOR
|
||||
CALL JPHL ; INDIRECT CALL (READ OR WRITE)
|
||||
OR A ; SET FLAGS ON RETURN CODE
|
||||
JP NZ,ERRIO ; IF NOT ZERO, ERROR ABORT
|
||||
; ADJUST BUFFER POINTER
|
||||
LD HL,(BUFPTR) ; GET BUFFER POINTER
|
||||
LD DE,128 ; RECORD LENGTH IS 128 BYTES
|
||||
ADD HL,DE ; ADJUST BUFFER PTR FOR NEXT RECORD
|
||||
LD (BUFPTR),HL ; SAVE IT
|
||||
; NEXT SECTOR
|
||||
LD HL,(ACTSEC) ; CURRENT SECTOR
|
||||
INC HL ; INCREMENT SECTOR
|
||||
LD (ACTSEC),HL ; SAVE IT
|
||||
; CHECK FOR END OF TRACK
|
||||
LD DE,(ACTSPT) ; GET CURRENT SECTORS PER TRACK
|
||||
OR A ; CLEAR CF
|
||||
SBC HL,DE ; CURRENT TRACK == SECTORS PER TRACK?
|
||||
JR NZ,RWDSK2 ; NO, SKIP TRACK CHANGE
|
||||
; NEXT TRACK
|
||||
LD HL,0
|
||||
LD (ACTSEC),HL ; CURRENT SECTOR := 0
|
||||
LD HL,ACTTRK ; POINT TO TRACK VARIABLE
|
||||
INC (HL) ; INCREMENT TRACK
|
||||
; CHECK PENDING RECORD COUNT AND LOOP OR RETURN
|
||||
RWDSK2: LD HL,RECCNT
|
||||
DEC (HL) ; DECREMENT PENDING RECORD COUNT
|
||||
RET Z ; IF ZERO, DONE, RETURN WITH Z SET
|
||||
JR RWDSK ; OTHERWISE, LOOP
|
||||
;
|
||||
JPHL: JP (HL) ; INDIRECT JUMP
|
||||
;
|
||||
; VERIFY SYSTEM IMAGE HEADER IN BUF BY CHECKING THE EXPECTED SIGNATURE.
|
||||
; COMPUTE AND RETURN IMAGE SIZE (BASED ON HEADER VALUES) IN HL.
|
||||
; NZ SET IF SIGNATURE ERROR.
|
||||
;
|
||||
CHKHDR:
|
||||
; CHECK SIGNATURE
|
||||
LD HL,(LOADP+580H) ; GET SIGNATURE
|
||||
LD DE,0A55AH ; SIGNATURE VALUE
|
||||
OR A ; CLEAR CF
|
||||
SBC HL,DE ; COMPARE
|
||||
JP NZ,ERRSIG ; INVALID SIGNATURE
|
||||
; COMPUTE THE IMAGE SIZE (DOES NOT INCLUDE SIZE OF HEADER)
|
||||
LD HL,(LOADP+5FCH) ; GET CPM_END
|
||||
LD DE,(LOADP+5FAH) ; GET CPM_LOC
|
||||
OR A ; CLEAR CF
|
||||
SBC HL,DE ; IMAGE SIZE := CPM_END - CPM_LOC
|
||||
XOR A ; SIGNAL SUCCESS
|
||||
RET ; DONE
|
||||
;
|
||||
; INVOKE CBIOS FUNCTION
|
||||
; THE CBIOS FUNCTION OFFSET MUST BE STORED IN THE BYTE
|
||||
; FOLLOWING THE CALL INSTRUCTION. EX:
|
||||
; CALL CBIOS
|
||||
; DB 0CH ; OFFSET OF CONOUT CBIOS FUNCTION
|
||||
;
|
||||
CBIOS:
|
||||
EX (SP),HL
|
||||
LD A,(HL) ; GET THE FUNCTION OFFSET
|
||||
INC HL ; POINT PAST VALUE FOLLOWING CALL INSTRUCTION
|
||||
EX (SP),HL ; PUT ADDRESS BACK AT TOP OF STACK AND RECOVER HL
|
||||
LD HL,(CBFTBL) ; ADDRESS OF CBIOS FUNCTION TABLE TO HL
|
||||
CALL ADDHL ; DETERMINE SPECIFIC FUNCTION ADDRESS
|
||||
JP (HL) ; INVOKE CBIOS
|
||||
;
|
||||
; ADD THE VALUE IN A TO HL (HL := HL + A)
|
||||
;
|
||||
ADDHL:
|
||||
ADD A,L ; A := A + L
|
||||
LD L,A ; PUT RESULT BACK IN L
|
||||
RET NC ; IF NO CARRY, WE ARE DONE
|
||||
INC H ; IF CARRY, INCREMENT H
|
||||
RET ; AND RETURN
|
||||
;
|
||||
; START OF PROGRAM
|
||||
;
|
||||
START:
|
||||
LD SP,STACK ; SET LOCAL STACK POINTER
|
||||
LD HL,SIGNON
|
||||
CALL CRMSG
|
||||
; LOCATE CBIOS FUNCTION TABLE ADDRESS
|
||||
LD HL,(BOOT+1) ; LOAD ADDRESS OF CP/M RESTART VECTOR
|
||||
LD DE,-3 ; ADJUSTMENT FOR START OF TABLE
|
||||
ADD HL,DE ; HL NOW HAS START OF TABLE
|
||||
LD (CBFTBL),HL ; SAVE IT
|
||||
; CHECK FOR DEFAULT FILE LOAD INSTEAD OF GET
|
||||
LD A,(FCB+1); BLANK IF NO FILE
|
||||
CP ' '
|
||||
JP Z,GETSYS ; SKIP TO GET SYSTEM MESSAGE IF BLANK
|
||||
LD DE,FCB ; TRY TO OPEN IT
|
||||
CALL OPEN ;
|
||||
INC A ; 255 BECOMES 00
|
||||
JP NZ,RDOK ; OK TO READ IF NOT 255
|
||||
; FILE NOT PRESENT, ERROR AND REBOOT
|
||||
LD HL,NOFILE
|
||||
CALL CRMSG
|
||||
JP REBOOT
|
||||
;
|
||||
; FILE PRESENT - READ TO LOAD POINT
|
||||
;
|
||||
RDOK:
|
||||
XOR A
|
||||
LD (FCBCR),A; CURRENT RECORD = 0
|
||||
; PRE-READ AREA FROM TPA TO LOADP
|
||||
LD C,(LOADP-TPA)/SECSIZ
|
||||
PRERD: ; PRE-READ FILE
|
||||
PUSH BC ; SAVE COUNT
|
||||
LD DE,FCB ; INPUT FILE CONTROL COUNT
|
||||
CALL DREAD ; ASSUME SET TO DEFAULT BUFFER
|
||||
POP BC ; RESTORE COUNT
|
||||
OR A
|
||||
JP NZ,BADRD ; CANNOT ENCOUNTER END-OF FILE
|
||||
DEC C ; COUNT DOWN
|
||||
JP NZ,PRERD ; FOR ANOTHER SECTOR
|
||||
;
|
||||
; SECTORS SKIPPED AT BEGINNING OF FILE
|
||||
;
|
||||
LD HL,LOADP
|
||||
RDINP:
|
||||
PUSH HL
|
||||
LD B,H
|
||||
LD C,L ; READY FOR DMA
|
||||
CALL CBIOS ; INVOKE CBIOS WITH...
|
||||
DB 024H ; SETDMA ENTRY OFFSET
|
||||
LD DE,FCB ; READY FOR READ
|
||||
CALL DREAD ;
|
||||
POP HL ; RECALL DMA ADDRESS
|
||||
OR A ; 00 IF READ OK
|
||||
JP NZ,PUTSYS ; ASSUME EOF IF NOT.
|
||||
; MORE TO READ, CONTINUE
|
||||
LD DE,SECSIZ
|
||||
ADD HL,DE ; HL IS NEW LOAD ADDRESS
|
||||
JP RDINP
|
||||
;
|
||||
BADRD: ; EOF ENCOUNTERED IN INPUT FILE
|
||||
LD HL,BADFILE
|
||||
CALL CRMSG
|
||||
JP REBOOT
|
||||
;
|
||||
GETSYS:
|
||||
CALL CRLF
|
||||
LD HL,ASKGET ; GET SYSTEM?
|
||||
CALL CRMSG
|
||||
CALL GETCHAR
|
||||
CP CR
|
||||
JP Z,PUTSYS ; SKIP IF CR ONLY
|
||||
;
|
||||
SUB 'A' ; NORMALIZE DRIVE NUMBER
|
||||
CP NDISKS ; VALID DRIVE?
|
||||
JP C,GETC ; SKIP TO GETC IF SO
|
||||
; INVALID DRIVE NUMBER
|
||||
CALL BADDISK
|
||||
JP GETSYS ; TO TRY AGAIN
|
||||
;
|
||||
GETC:
|
||||
; SELECT DISK GIVEN BY REGISTER A
|
||||
ADD A,'A'
|
||||
LD (GDISK),A; TO SET MESSAGE
|
||||
SUB 'A'
|
||||
LD (ACTDSK),A ; SAVE ACTIVE DISK NO
|
||||
|
||||
; ; GETSYS, SET RW TO READ AND GET THE SYSTEM
|
||||
CALL CRLF
|
||||
LD HL,GETMSG
|
||||
CALL OUTMSG
|
||||
CALL GETCHAR
|
||||
CP CR
|
||||
JP NZ,REBOOT
|
||||
CALL CRLF
|
||||
CALL RDDSK
|
||||
JP NZ,GETSYS
|
||||
LD HL,DONE
|
||||
CALL OUTMSG
|
||||
;
|
||||
; PUT SYSTEM
|
||||
;
|
||||
PUTSYS:
|
||||
CALL CRLF
|
||||
LD HL,ASKPUT
|
||||
CALL CRMSG
|
||||
CALL GETCHAR
|
||||
CP CR
|
||||
JP Z,REBOOT
|
||||
SUB 'A'
|
||||
CP NDISKS
|
||||
JP C,PUTC
|
||||
; INVALID DRIVE NAME
|
||||
CALL BADDISK
|
||||
JP PUTSYS ; TO TRY AGAIN
|
||||
;
|
||||
PUTC: ; SET DISK FROM REGISTER C
|
||||
ADD A,'A'
|
||||
LD (PDISK),A ; MESSAGE SET
|
||||
SUB 'A'
|
||||
LD (ACTDSK),A ; SAVE ACTIVE DISK NO
|
||||
|
||||
; PUT SYSTEM
|
||||
LD HL,PUTMSG
|
||||
CALL CRMSG
|
||||
CALL GETCHAR
|
||||
CP CR
|
||||
JP NZ,REBOOT
|
||||
CALL CRLF
|
||||
CALL WRDSK
|
||||
JP NZ,PUTSYS
|
||||
LD HL,DONE
|
||||
CALL OUTMSG
|
||||
JP PUTSYS ; FOR ANOTHER PUT OPERATION
|
||||
;
|
||||
REBOOT:
|
||||
CALL CRLF
|
||||
JP BOOT
|
||||
;
|
||||
ERRSEL:
|
||||
LD HL,SELMSG
|
||||
JP ERR
|
||||
;
|
||||
ERRSYS:
|
||||
LD HL,SYSMSG
|
||||
JP ERR
|
||||
;
|
||||
ERRIO:
|
||||
LD HL,IOMSG
|
||||
JP ERR
|
||||
;
|
||||
ERRSIG:
|
||||
LD HL,SIGMSG
|
||||
JP ERR
|
||||
;
|
||||
ERR:
|
||||
CALL OUTMSG
|
||||
OR A,0FFH
|
||||
RET
|
||||
;
|
||||
BADDISK:;BAD DISK NAME
|
||||
LD HL,QDISK
|
||||
CALL CRMSG
|
||||
RET
|
||||
;
|
||||
; DATA AREAS
|
||||
; MESSAGES
|
||||
;
|
||||
SIGNON: DB 'ROMWBW SYSGEN VER '
|
||||
DB VERS/10+'0','.',VERS MOD 10+'0'
|
||||
DB 0
|
||||
ASKGET: DB 'SOURCE DRIVE NAME (OR RETURN TO SKIP): ',0
|
||||
GETMSG: DB 'SOURCE ON '
|
||||
GDISK: DS 1 ; FILLED IN AT GET FUNCTION
|
||||
DB ':, THEN TYPE RETURN',0
|
||||
ASKPUT: DB 'DESTINATION DRIVE NAME (OR RETURN TO REBOOT): ',0
|
||||
PUTMSG: DB 'DESTINATION ON '
|
||||
PDISK: DS 1 ; FILLED IN AT PUT FUNCTION
|
||||
DB ':, THEN TYPE RETURN',0
|
||||
ERRMSG: DB 'PERMANENT ERROR, TYPE RETURN TO IGNORE',0
|
||||
DONE: DB 'FUNCTION COMPLETE',0
|
||||
QDISK: DB 'INVALID DRIVE NAME (USE A-P)',0
|
||||
NOFILE: DB 'NO SOURCE FILE ON DISK',0
|
||||
BADFILE:
|
||||
DB 'SOURCE FILE INCOMPLETE',0
|
||||
SELMSG: DB 'DISK SELECTION ERROR',0
|
||||
SYSMSG: DB 'NON-SYSTEM DISK ERROR',0
|
||||
IOMSG: DB 'FATAL DISK I/O ERROR',0
|
||||
SIGMSG: DB 'INVALID SYSTEM IMAGE (BAD SIGNATURE)',0
|
||||
;
|
||||
; VARIABLES
|
||||
;
|
||||
CBFTBL DW 0 ; ADDRESS OF CBIOS FUNCTION TABLE
|
||||
IMGSIZ DB 0 ; IMAGE SIZE (COUNT OF 128 BYTE RECORDS)
|
||||
;
|
||||
RWFUN DB 0 ; ACTIVE READ/WRITE FUNCTION
|
||||
RECCNT DB 0 ; ACTIVE REMAINING RECORDS TO READ/WRITE
|
||||
BUFPTR DW 0 ; ACTIVE POINTER INTO BUFFER
|
||||
;
|
||||
ACTDSK DB 0 ; ACTIVE DISK NO
|
||||
ACTTRK DW 0 ; ACTIVE TRACK
|
||||
ACTSEC DW 0 ; ACTIVE SECTOR
|
||||
ACTSPT DW 0 ; ACTIVE SECTORS PER TRACK
|
||||
ACTFNC DW 0 ; ACTIVE FUNCTION (READ OR WRITE)
|
||||
DS STKSIZE*2
|
||||
STACK:
|
||||
;
|
||||
END
|
||||
16
Binary/Apps/Clean.cmd
Normal file
16
Binary/Apps/Clean.cmd
Normal file
@@ -0,0 +1,16 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
if exist *.com del *.com
|
||||
if exist *.ovr del *.ovr
|
||||
if exist *.doc del *.doc
|
||||
if exist *.hlp del *.hlp
|
||||
if exist Tunes\*.pt? del Tunes\*.pt?
|
||||
if exist Tunes\*.mym del Tunes\*.mym
|
||||
if exist Tunes\*.vgm del Tunes\*.vgm
|
||||
if exist bbcbasic.txt del bbcbasic.txt
|
||||
if exist *.cfg del *.cfg
|
||||
if exist *.fon del *.fon
|
||||
|
||||
pushd Test && call Clean || exit /b 1 & popd
|
||||
pushd ZDE && call Clean || exit /b 1 & popd
|
||||
11
Binary/Apps/Makefile
Normal file
11
Binary/Apps/Makefile
Normal file
@@ -0,0 +1,11 @@
|
||||
TOOLS = ../../Tools
|
||||
MOREDIFF := $(shell $(TOOLS)/unix/casefn.sh *.com)
|
||||
SUBDIRS = Test ZDE
|
||||
|
||||
include $(TOOLS)/Makefile.inc
|
||||
|
||||
all::
|
||||
mkdir -p Tunes
|
||||
|
||||
clean::
|
||||
@rm -f *.bin *.com *.img *.rom *.pdf *.log *.eeprom *.ovr *.hlp *.doc *.COM *.BIN Tunes/*.mym Tunes/*.pt? Tunes/*.vgm bbcbasic.txt *.cfg *.fon
|
||||
21
Binary/Apps/ReadMe.txt
Normal file
21
Binary/Apps/ReadMe.txt
Normal file
@@ -0,0 +1,21 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory contains the executable application files that
|
||||
are specific to RomWBW. The source for these applications is found
|
||||
in the Source\Apps directory of the distribution.
|
||||
|
||||
The Tunes subdirectory contains some sample ProTracker and MYM sound
|
||||
files that can be played by the TUNE application.
|
||||
|
||||
All of these files are already included in the pre-built boot disk
|
||||
images. They are also included on the ROM disk except for
|
||||
FAT.COM, TUNE.COM, and the sample tune files in the Tunes directory.
|
||||
|
||||
If you upgrade your ROM to a new version, you should also copy
|
||||
these files over to any hard disk images you are using.
|
||||
4
Binary/Apps/Test/Clean.cmd
Normal file
4
Binary/Apps/Test/Clean.cmd
Normal file
@@ -0,0 +1,4 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
if exist *.com del *.com
|
||||
7
Binary/Apps/Test/Makefile
Normal file
7
Binary/Apps/Test/Makefile
Normal file
@@ -0,0 +1,7 @@
|
||||
TOOLS = ../../../Tools
|
||||
MOREDIFF := $(shell $(TOOLS)/unix/casefn.sh *.com)
|
||||
|
||||
include $(TOOLS)/Makefile.inc
|
||||
|
||||
clean::
|
||||
@rm -f *.com
|
||||
16
Binary/Apps/Test/ReadMe.txt
Normal file
16
Binary/Apps/Test/ReadMe.txt
Normal file
@@ -0,0 +1,16 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory contains various hardware test application files that
|
||||
are specific to RomWBW. The source for these applications is found
|
||||
in the Source\Apps\Test directory of the distribution.
|
||||
|
||||
These files are included on the pre-built disk images in user area 2.
|
||||
|
||||
N.B., these files may be specific to certain hardware. They should
|
||||
be used as directred by the instructions for your specific hardware.
|
||||
44
Binary/Apps/Test/inttest.doc
Normal file
44
Binary/Apps/Test/inttest.doc
Normal file
@@ -0,0 +1,44 @@
|
||||
INTTEST
|
||||
=======
|
||||
|
||||
RomWBW includes an API allowing applications to "hook" interrupts.
|
||||
The `INTTEST` utility allows you to test this functionality.
|
||||
|
||||
|
||||
** Syntax **
|
||||
|
||||
`INTTEST`
|
||||
|
||||
|
||||
** Usage **
|
||||
|
||||
`INTTEST` is an interactive application. At startup, it will display
|
||||
a list of the interrupt vector slots in your system along with the
|
||||
current vector address for each of them.
|
||||
|
||||
It then prompts you to enter the slot number (in hex) of a vector to
|
||||
hook. After entering this, the application will watch the hooked
|
||||
vector and countdown from 0xFF to 0x00 as interrupts are noted.
|
||||
|
||||
When the counter reaches 0x00, the interrupt is unhooked and the
|
||||
application terminates. The application can also be terminated by
|
||||
pressing <esc>.
|
||||
|
||||
|
||||
** Notes **
|
||||
|
||||
If your system is running without interrupts active, the application
|
||||
will terminate immediately.
|
||||
|
||||
All slots have vectors even if the corresponding interrupt is not
|
||||
doing anything. In this case, the vector is pointing to the "bad
|
||||
interrupt" handler.
|
||||
|
||||
If you hook a vector that is not receiving any interrupts, the
|
||||
down-counter will not do anything.
|
||||
|
||||
|
||||
** Etymology* *
|
||||
|
||||
The `INTTEST` command is an original product and the source code is
|
||||
provided in the RomWBW distribution.
|
||||
10
Binary/Apps/Tunes/ReadMe.txt
Normal file
10
Binary/Apps/Tunes/ReadMe.txt
Normal file
@@ -0,0 +1,10 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory contains some sample ProTracker and MYM sound
|
||||
files that can be played by the TUNE or VGMPLAY application.
|
||||
4
Binary/Apps/ZDE/Clean.cmd
Normal file
4
Binary/Apps/ZDE/Clean.cmd
Normal file
@@ -0,0 +1,4 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
if exist *.com del *.com
|
||||
6
Binary/Apps/ZDE/Makefile
Normal file
6
Binary/Apps/ZDE/Makefile
Normal file
@@ -0,0 +1,6 @@
|
||||
TOOLS = ../../../Tools
|
||||
|
||||
include $(TOOLS)/Makefile.inc
|
||||
|
||||
clean::
|
||||
@rm -f *.com
|
||||
10
Binary/Apps/ZDE/ReadMe.txt
Normal file
10
Binary/Apps/ZDE/ReadMe.txt
Normal file
@@ -0,0 +1,10 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory contains the ZDE executable binaries. They are
|
||||
in their original, unconfigured state.
|
||||
4
Binary/CPM22/Clean.cmd
Normal file
4
Binary/CPM22/Clean.cmd
Normal file
@@ -0,0 +1,4 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
if exist *.sys del *.sys
|
||||
7
Binary/CPM22/Makefile
Normal file
7
Binary/CPM22/Makefile
Normal file
@@ -0,0 +1,7 @@
|
||||
TOOLS = ../../Tools
|
||||
MOREDIFF := $(shell $(TOOLS)/unix/casefn.sh *.spr)
|
||||
|
||||
include $(TOOLS)/Makefile.inc
|
||||
|
||||
clean::
|
||||
@rm -f *.sys
|
||||
23
Binary/CPM22/ReadMe.txt
Normal file
23
Binary/CPM22/ReadMe.txt
Normal file
@@ -0,0 +1,23 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory contains the CP/M 2.2 system files for the RomWBW CP/M 2.2
|
||||
adaptation. All of these files are already included on the CP/M
|
||||
boot disk images. However if you are creating a CP/M boot disk
|
||||
manually, you should copy all of these files to the boot disk.
|
||||
|
||||
Note: Two file have been provided one for RomWBW HBIOS, and one for UNA
|
||||
BIOS. One of these files must be installed on the system boot track.
|
||||
This is usually achieved by the SYSCOPY utility e.g.
|
||||
|
||||
SYSCOPY a:=cpm_wbw.sys
|
||||
|
||||
These files should also be copied to any CP/M 2.2 boot disks on your
|
||||
system when you upgrade your ROM firmware. Some of these files
|
||||
*must* match the version of the RomWBW firmware you are using for
|
||||
proper operation of your system.
|
||||
11
Binary/CPM3/Clean.cmd
Normal file
11
Binary/CPM3/Clean.cmd
Normal file
@@ -0,0 +1,11 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
if exist *.spr del *.spr
|
||||
if exist *.com del *.com
|
||||
if exist *.sys del *.sys
|
||||
if exist *.pat del *.pat
|
||||
if exist *.dat del *.dat
|
||||
if exist *.1st del *.1st
|
||||
if exist *.spr del *.spr
|
||||
if exist *.pat del *.pat
|
||||
7
Binary/CPM3/Makefile
Normal file
7
Binary/CPM3/Makefile
Normal file
@@ -0,0 +1,7 @@
|
||||
TOOLS = ../../Tools
|
||||
MOREDIFF := $(shell $(TOOLS)/unix/casefn.sh *.spr)
|
||||
|
||||
include $(TOOLS)/Makefile.inc
|
||||
|
||||
clean::
|
||||
@rm -f *.spr *.com *.sys *.dat cpm3fix.pat readme.1st
|
||||
17
Binary/CPM3/ReadMe.txt
Normal file
17
Binary/CPM3/ReadMe.txt
Normal file
@@ -0,0 +1,17 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory contains the CP/M 3 system files for the RomWBW CP/M 3
|
||||
adaptation. All of these files are already included on the CP/M 3
|
||||
boot disk images. However if you are creating a CP/M 3 boot disk
|
||||
manually, you should copy all of these files to the boot disk.
|
||||
|
||||
These files should also be copied to any CP/M 3 boot disks on your
|
||||
system when you upgrade your ROM firmware. Some of these files
|
||||
*must* match the version of the RomWBW firmware you are using for
|
||||
proper operation of your system.
|
||||
4
Binary/CPNET/Clean.cmd
Normal file
4
Binary/CPNET/Clean.cmd
Normal file
@@ -0,0 +1,4 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
if exist *.lbr del *.lbr
|
||||
7
Binary/CPNET/Makefile
Normal file
7
Binary/CPNET/Makefile
Normal file
@@ -0,0 +1,7 @@
|
||||
TOOLS = ../../Tools
|
||||
MOREDIFF := $(shell $(TOOLS)/unix/casefn.sh *.lbr)
|
||||
|
||||
include $(TOOLS)/Makefile.inc
|
||||
|
||||
clean::
|
||||
@rm -f *.lbr
|
||||
BIN
Binary/CPNET/NetBoot/DUO/ccp.spr
Normal file
BIN
Binary/CPNET/NetBoot/DUO/ccp.spr
Normal file
Binary file not shown.
BIN
Binary/CPNET/NetBoot/DUO/cpnos.sys
Normal file
BIN
Binary/CPNET/NetBoot/DUO/cpnos.sys
Normal file
Binary file not shown.
BIN
Binary/CPNET/NetBoot/DUO/ndos.spr
Normal file
BIN
Binary/CPNET/NetBoot/DUO/ndos.spr
Normal file
Binary file not shown.
BIN
Binary/CPNET/NetBoot/DUO/snios.spr
Normal file
BIN
Binary/CPNET/NetBoot/DUO/snios.spr
Normal file
Binary file not shown.
BIN
Binary/CPNET/NetBoot/MT/ccp.spr
Normal file
BIN
Binary/CPNET/NetBoot/MT/ccp.spr
Normal file
Binary file not shown.
BIN
Binary/CPNET/NetBoot/MT/cpnos.sys
Normal file
BIN
Binary/CPNET/NetBoot/MT/cpnos.sys
Normal file
Binary file not shown.
BIN
Binary/CPNET/NetBoot/MT/ndos.spr
Normal file
BIN
Binary/CPNET/NetBoot/MT/ndos.spr
Normal file
Binary file not shown.
BIN
Binary/CPNET/NetBoot/MT/snios.spr
Normal file
BIN
Binary/CPNET/NetBoot/MT/snios.spr
Normal file
Binary file not shown.
38
Binary/CPNET/ReadMe.txt
Normal file
38
Binary/CPNET/ReadMe.txt
Normal file
@@ -0,0 +1,38 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory contains the CP/NET client packages. Please refer to
|
||||
the RomWBW User Guide for instructions on installing these packages.
|
||||
Either the MT011 RCBus module or the Duodyne Disk I/O board is required.
|
||||
|
||||
All of these files come from Douglas Miller. Please refer to
|
||||
https://github.com/durgadas311/cpnet-z80 for more information, complete
|
||||
documentation and the latest source code. Refer to the RomWBW
|
||||
User Guide for basic installation and usage instructions under RomWBW.
|
||||
|
||||
| File | CP/NET Version | OS | Hardware |
|
||||
+--------------+----------------+----------+-----------------------+
|
||||
| CPN12MT.LBR | CP/NET 1.2 | CP/M 2.2 | RCBus w/ MT011 |
|
||||
| CPN3MT.LBR | CP/NET 3 | CP/M 3 | RCBus w/ MT011 |
|
||||
| CPN12DUO.LBR | CP/NET 1.2 | CP/M 2.2 | Duodyne w/ Disk I/O |
|
||||
| CPN3DUO.LBR | CP/NET 3 | CP/M 3 | Duodyne w/ Disk I/O |
|
||||
|
||||
In general, to use CP/NET on RomWBW, it is intended that you will
|
||||
extract the appropriate set of files into your default directory in
|
||||
user area 0. Refer to the RomWBW User Guide for more information.
|
||||
|
||||
The libraries include enhanced help files appropriate for the version
|
||||
of CP/NET. Rename the desired topic collection to HELP.HLP on the
|
||||
target system.
|
||||
|
||||
CPM2NET.HLP CP/M 2.2 basic system with CP/NET 1.2
|
||||
CPNET12.HLP CP/NET 1.2 help only
|
||||
CPM3NET.HLP CP/M 3 basic system with CP/NET 3
|
||||
CPNET3.HLP CP/NET 3 help only
|
||||
|
||||
-- WBW 7:14 AM 2/11/2024
|
||||
20
Binary/Clean.cmd
Normal file
20
Binary/Clean.cmd
Normal file
@@ -0,0 +1,20 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
if exist *.bin del *.bin
|
||||
if exist *.dat del *.dat
|
||||
if exist *.com del *.com
|
||||
if exist *.img del *.img
|
||||
if exist *.rom del *.rom
|
||||
if exist *.hex del *.hex
|
||||
if exist *.upd del *.upd
|
||||
if exist *.pdf del *.pdf
|
||||
if exist *.eeprom del *.eeprom
|
||||
|
||||
pushd Apps && call Clean || exit /b 1 & popd
|
||||
pushd CPM22 && call Clean || exit /b 1 & popd
|
||||
pushd CPM3 && call Clean || exit /b 1 & popd
|
||||
pushd QPM && call Clean || exit /b 1 & popd
|
||||
pushd ZSDOS && call Clean || exit /b 1 & popd
|
||||
pushd ZPM3 && call Clean || exit /b 1 & popd
|
||||
pushd CPNET && call Clean || exit /b 1 & popd
|
||||
674
Binary/GPL-3.0.txt
Normal file
674
Binary/GPL-3.0.txt
Normal file
@@ -0,0 +1,674 @@
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
Version 3, 29 June 2007
|
||||
|
||||
Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The GNU General Public License is a free, copyleft license for
|
||||
software and other kinds of works.
|
||||
|
||||
The licenses for most software and other practical works are designed
|
||||
to take away your freedom to share and change the works. By contrast,
|
||||
the GNU General Public License is intended to guarantee your freedom to
|
||||
share and change all versions of a program--to make sure it remains free
|
||||
software for all its users. We, the Free Software Foundation, use the
|
||||
GNU General Public License for most of our software; it applies also to
|
||||
any other work released this way by its authors. You can apply it to
|
||||
your programs, too.
|
||||
|
||||
When we speak of free software, we are referring to freedom, not
|
||||
price. Our General Public Licenses are designed to make sure that you
|
||||
have the freedom to distribute copies of free software (and charge for
|
||||
them if you wish), that you receive source code or can get it if you
|
||||
want it, that you can change the software or use pieces of it in new
|
||||
free programs, and that you know you can do these things.
|
||||
|
||||
To protect your rights, we need to prevent others from denying you
|
||||
these rights or asking you to surrender the rights. Therefore, you have
|
||||
certain responsibilities if you distribute copies of the software, or if
|
||||
you modify it: responsibilities to respect the freedom of others.
|
||||
|
||||
For example, if you distribute copies of such a program, whether
|
||||
gratis or for a fee, you must pass on to the recipients the same
|
||||
freedoms that you received. You must make sure that they, too, receive
|
||||
or can get the source code. And you must show them these terms so they
|
||||
know their rights.
|
||||
|
||||
Developers that use the GNU GPL protect your rights with two steps:
|
||||
(1) assert copyright on the software, and (2) offer you this License
|
||||
giving you legal permission to copy, distribute and/or modify it.
|
||||
|
||||
For the developers' and authors' protection, the GPL clearly explains
|
||||
that there is no warranty for this free software. For both users' and
|
||||
authors' sake, the GPL requires that modified versions be marked as
|
||||
changed, so that their problems will not be attributed erroneously to
|
||||
authors of previous versions.
|
||||
|
||||
Some devices are designed to deny users access to install or run
|
||||
modified versions of the software inside them, although the manufacturer
|
||||
can do so. This is fundamentally incompatible with the aim of
|
||||
protecting users' freedom to change the software. The systematic
|
||||
pattern of such abuse occurs in the area of products for individuals to
|
||||
use, which is precisely where it is most unacceptable. Therefore, we
|
||||
have designed this version of the GPL to prohibit the practice for those
|
||||
products. If such problems arise substantially in other domains, we
|
||||
stand ready to extend this provision to those domains in future versions
|
||||
of the GPL, as needed to protect the freedom of users.
|
||||
|
||||
Finally, every program is threatened constantly by software patents.
|
||||
States should not allow patents to restrict development and use of
|
||||
software on general-purpose computers, but in those that do, we wish to
|
||||
avoid the special danger that patents applied to a free program could
|
||||
make it effectively proprietary. To prevent this, the GPL assures that
|
||||
patents cannot be used to render the program non-free.
|
||||
|
||||
The precise terms and conditions for copying, distribution and
|
||||
modification follow.
|
||||
|
||||
TERMS AND CONDITIONS
|
||||
|
||||
0. Definitions.
|
||||
|
||||
"This License" refers to version 3 of the GNU General Public License.
|
||||
|
||||
"Copyright" also means copyright-like laws that apply to other kinds of
|
||||
works, such as semiconductor masks.
|
||||
|
||||
"The Program" refers to any copyrightable work licensed under this
|
||||
License. Each licensee is addressed as "you". "Licensees" and
|
||||
"recipients" may be individuals or organizations.
|
||||
|
||||
To "modify" a work means to copy from or adapt all or part of the work
|
||||
in a fashion requiring copyright permission, other than the making of an
|
||||
exact copy. The resulting work is called a "modified version" of the
|
||||
earlier work or a work "based on" the earlier work.
|
||||
|
||||
A "covered work" means either the unmodified Program or a work based
|
||||
on the Program.
|
||||
|
||||
To "propagate" a work means to do anything with it that, without
|
||||
permission, would make you directly or secondarily liable for
|
||||
infringement under applicable copyright law, except executing it on a
|
||||
computer or modifying a private copy. Propagation includes copying,
|
||||
distribution (with or without modification), making available to the
|
||||
public, and in some countries other activities as well.
|
||||
|
||||
To "convey" a work means any kind of propagation that enables other
|
||||
parties to make or receive copies. Mere interaction with a user through
|
||||
a computer network, with no transfer of a copy, is not conveying.
|
||||
|
||||
An interactive user interface displays "Appropriate Legal Notices"
|
||||
to the extent that it includes a convenient and prominently visible
|
||||
feature that (1) displays an appropriate copyright notice, and (2)
|
||||
tells the user that there is no warranty for the work (except to the
|
||||
extent that warranties are provided), that licensees may convey the
|
||||
work under this License, and how to view a copy of this License. If
|
||||
the interface presents a list of user commands or options, such as a
|
||||
menu, a prominent item in the list meets this criterion.
|
||||
|
||||
1. Source Code.
|
||||
|
||||
The "source code" for a work means the preferred form of the work
|
||||
for making modifications to it. "Object code" means any non-source
|
||||
form of a work.
|
||||
|
||||
A "Standard Interface" means an interface that either is an official
|
||||
standard defined by a recognized standards body, or, in the case of
|
||||
interfaces specified for a particular programming language, one that
|
||||
is widely used among developers working in that language.
|
||||
|
||||
The "System Libraries" of an executable work include anything, other
|
||||
than the work as a whole, that (a) is included in the normal form of
|
||||
packaging a Major Component, but which is not part of that Major
|
||||
Component, and (b) serves only to enable use of the work with that
|
||||
Major Component, or to implement a Standard Interface for which an
|
||||
implementation is available to the public in source code form. A
|
||||
"Major Component", in this context, means a major essential component
|
||||
(kernel, window system, and so on) of the specific operating system
|
||||
(if any) on which the executable work runs, or a compiler used to
|
||||
produce the work, or an object code interpreter used to run it.
|
||||
|
||||
The "Corresponding Source" for a work in object code form means all
|
||||
the source code needed to generate, install, and (for an executable
|
||||
work) run the object code and to modify the work, including scripts to
|
||||
control those activities. However, it does not include the work's
|
||||
System Libraries, or general-purpose tools or generally available free
|
||||
programs which are used unmodified in performing those activities but
|
||||
which are not part of the work. For example, Corresponding Source
|
||||
includes interface definition files associated with source files for
|
||||
the work, and the source code for shared libraries and dynamically
|
||||
linked subprograms that the work is specifically designed to require,
|
||||
such as by intimate data communication or control flow between those
|
||||
subprograms and other parts of the work.
|
||||
|
||||
The Corresponding Source need not include anything that users
|
||||
can regenerate automatically from other parts of the Corresponding
|
||||
Source.
|
||||
|
||||
The Corresponding Source for a work in source code form is that
|
||||
same work.
|
||||
|
||||
2. Basic Permissions.
|
||||
|
||||
All rights granted under this License are granted for the term of
|
||||
copyright on the Program, and are irrevocable provided the stated
|
||||
conditions are met. This License explicitly affirms your unlimited
|
||||
permission to run the unmodified Program. The output from running a
|
||||
covered work is covered by this License only if the output, given its
|
||||
content, constitutes a covered work. This License acknowledges your
|
||||
rights of fair use or other equivalent, as provided by copyright law.
|
||||
|
||||
You may make, run and propagate covered works that you do not
|
||||
convey, without conditions so long as your license otherwise remains
|
||||
in force. You may convey covered works to others for the sole purpose
|
||||
of having them make modifications exclusively for you, or provide you
|
||||
with facilities for running those works, provided that you comply with
|
||||
the terms of this License in conveying all material for which you do
|
||||
not control copyright. Those thus making or running the covered works
|
||||
for you must do so exclusively on your behalf, under your direction
|
||||
and control, on terms that prohibit them from making any copies of
|
||||
your copyrighted material outside their relationship with you.
|
||||
|
||||
Conveying under any other circumstances is permitted solely under
|
||||
the conditions stated below. Sublicensing is not allowed; section 10
|
||||
makes it unnecessary.
|
||||
|
||||
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
|
||||
|
||||
No covered work shall be deemed part of an effective technological
|
||||
measure under any applicable law fulfilling obligations under article
|
||||
11 of the WIPO copyright treaty adopted on 20 December 1996, or
|
||||
similar laws prohibiting or restricting circumvention of such
|
||||
measures.
|
||||
|
||||
When you convey a covered work, you waive any legal power to forbid
|
||||
circumvention of technological measures to the extent such circumvention
|
||||
is effected by exercising rights under this License with respect to
|
||||
the covered work, and you disclaim any intention to limit operation or
|
||||
modification of the work as a means of enforcing, against the work's
|
||||
users, your or third parties' legal rights to forbid circumvention of
|
||||
technological measures.
|
||||
|
||||
4. Conveying Verbatim Copies.
|
||||
|
||||
You may convey verbatim copies of the Program's source code as you
|
||||
receive it, in any medium, provided that you conspicuously and
|
||||
appropriately publish on each copy an appropriate copyright notice;
|
||||
keep intact all notices stating that this License and any
|
||||
non-permissive terms added in accord with section 7 apply to the code;
|
||||
keep intact all notices of the absence of any warranty; and give all
|
||||
recipients a copy of this License along with the Program.
|
||||
|
||||
You may charge any price or no price for each copy that you convey,
|
||||
and you may offer support or warranty protection for a fee.
|
||||
|
||||
5. Conveying Modified Source Versions.
|
||||
|
||||
You may convey a work based on the Program, or the modifications to
|
||||
produce it from the Program, in the form of source code under the
|
||||
terms of section 4, provided that you also meet all of these conditions:
|
||||
|
||||
a) The work must carry prominent notices stating that you modified
|
||||
it, and giving a relevant date.
|
||||
|
||||
b) The work must carry prominent notices stating that it is
|
||||
released under this License and any conditions added under section
|
||||
7. This requirement modifies the requirement in section 4 to
|
||||
"keep intact all notices".
|
||||
|
||||
c) You must license the entire work, as a whole, under this
|
||||
License to anyone who comes into possession of a copy. This
|
||||
License will therefore apply, along with any applicable section 7
|
||||
additional terms, to the whole of the work, and all its parts,
|
||||
regardless of how they are packaged. This License gives no
|
||||
permission to license the work in any other way, but it does not
|
||||
invalidate such permission if you have separately received it.
|
||||
|
||||
d) If the work has interactive user interfaces, each must display
|
||||
Appropriate Legal Notices; however, if the Program has interactive
|
||||
interfaces that do not display Appropriate Legal Notices, your
|
||||
work need not make them do so.
|
||||
|
||||
A compilation of a covered work with other separate and independent
|
||||
works, which are not by their nature extensions of the covered work,
|
||||
and which are not combined with it such as to form a larger program,
|
||||
in or on a volume of a storage or distribution medium, is called an
|
||||
"aggregate" if the compilation and its resulting copyright are not
|
||||
used to limit the access or legal rights of the compilation's users
|
||||
beyond what the individual works permit. Inclusion of a covered work
|
||||
in an aggregate does not cause this License to apply to the other
|
||||
parts of the aggregate.
|
||||
|
||||
6. Conveying Non-Source Forms.
|
||||
|
||||
You may convey a covered work in object code form under the terms
|
||||
of sections 4 and 5, provided that you also convey the
|
||||
machine-readable Corresponding Source under the terms of this License,
|
||||
in one of these ways:
|
||||
|
||||
a) Convey the object code in, or embodied in, a physical product
|
||||
(including a physical distribution medium), accompanied by the
|
||||
Corresponding Source fixed on a durable physical medium
|
||||
customarily used for software interchange.
|
||||
|
||||
b) Convey the object code in, or embodied in, a physical product
|
||||
(including a physical distribution medium), accompanied by a
|
||||
written offer, valid for at least three years and valid for as
|
||||
long as you offer spare parts or customer support for that product
|
||||
model, to give anyone who possesses the object code either (1) a
|
||||
copy of the Corresponding Source for all the software in the
|
||||
product that is covered by this License, on a durable physical
|
||||
medium customarily used for software interchange, for a price no
|
||||
more than your reasonable cost of physically performing this
|
||||
conveying of source, or (2) access to copy the
|
||||
Corresponding Source from a network server at no charge.
|
||||
|
||||
c) Convey individual copies of the object code with a copy of the
|
||||
written offer to provide the Corresponding Source. This
|
||||
alternative is allowed only occasionally and noncommercially, and
|
||||
only if you received the object code with such an offer, in accord
|
||||
with subsection 6b.
|
||||
|
||||
d) Convey the object code by offering access from a designated
|
||||
place (gratis or for a charge), and offer equivalent access to the
|
||||
Corresponding Source in the same way through the same place at no
|
||||
further charge. You need not require recipients to copy the
|
||||
Corresponding Source along with the object code. If the place to
|
||||
copy the object code is a network server, the Corresponding Source
|
||||
may be on a different server (operated by you or a third party)
|
||||
that supports equivalent copying facilities, provided you maintain
|
||||
clear directions next to the object code saying where to find the
|
||||
Corresponding Source. Regardless of what server hosts the
|
||||
Corresponding Source, you remain obligated to ensure that it is
|
||||
available for as long as needed to satisfy these requirements.
|
||||
|
||||
e) Convey the object code using peer-to-peer transmission, provided
|
||||
you inform other peers where the object code and Corresponding
|
||||
Source of the work are being offered to the general public at no
|
||||
charge under subsection 6d.
|
||||
|
||||
A separable portion of the object code, whose source code is excluded
|
||||
from the Corresponding Source as a System Library, need not be
|
||||
included in conveying the object code work.
|
||||
|
||||
A "User Product" is either (1) a "consumer product", which means any
|
||||
tangible personal property which is normally used for personal, family,
|
||||
or household purposes, or (2) anything designed or sold for incorporation
|
||||
into a dwelling. In determining whether a product is a consumer product,
|
||||
doubtful cases shall be resolved in favor of coverage. For a particular
|
||||
product received by a particular user, "normally used" refers to a
|
||||
typical or common use of that class of product, regardless of the status
|
||||
of the particular user or of the way in which the particular user
|
||||
actually uses, or expects or is expected to use, the product. A product
|
||||
is a consumer product regardless of whether the product has substantial
|
||||
commercial, industrial or non-consumer uses, unless such uses represent
|
||||
the only significant mode of use of the product.
|
||||
|
||||
"Installation Information" for a User Product means any methods,
|
||||
procedures, authorization keys, or other information required to install
|
||||
and execute modified versions of a covered work in that User Product from
|
||||
a modified version of its Corresponding Source. The information must
|
||||
suffice to ensure that the continued functioning of the modified object
|
||||
code is in no case prevented or interfered with solely because
|
||||
modification has been made.
|
||||
|
||||
If you convey an object code work under this section in, or with, or
|
||||
specifically for use in, a User Product, and the conveying occurs as
|
||||
part of a transaction in which the right of possession and use of the
|
||||
User Product is transferred to the recipient in perpetuity or for a
|
||||
fixed term (regardless of how the transaction is characterized), the
|
||||
Corresponding Source conveyed under this section must be accompanied
|
||||
by the Installation Information. But this requirement does not apply
|
||||
if neither you nor any third party retains the ability to install
|
||||
modified object code on the User Product (for example, the work has
|
||||
been installed in ROM).
|
||||
|
||||
The requirement to provide Installation Information does not include a
|
||||
requirement to continue to provide support service, warranty, or updates
|
||||
for a work that has been modified or installed by the recipient, or for
|
||||
the User Product in which it has been modified or installed. Access to a
|
||||
network may be denied when the modification itself materially and
|
||||
adversely affects the operation of the network or violates the rules and
|
||||
protocols for communication across the network.
|
||||
|
||||
Corresponding Source conveyed, and Installation Information provided,
|
||||
in accord with this section must be in a format that is publicly
|
||||
documented (and with an implementation available to the public in
|
||||
source code form), and must require no special password or key for
|
||||
unpacking, reading or copying.
|
||||
|
||||
7. Additional Terms.
|
||||
|
||||
"Additional permissions" are terms that supplement the terms of this
|
||||
License by making exceptions from one or more of its conditions.
|
||||
Additional permissions that are applicable to the entire Program shall
|
||||
be treated as though they were included in this License, to the extent
|
||||
that they are valid under applicable law. If additional permissions
|
||||
apply only to part of the Program, that part may be used separately
|
||||
under those permissions, but the entire Program remains governed by
|
||||
this License without regard to the additional permissions.
|
||||
|
||||
When you convey a copy of a covered work, you may at your option
|
||||
remove any additional permissions from that copy, or from any part of
|
||||
it. (Additional permissions may be written to require their own
|
||||
removal in certain cases when you modify the work.) You may place
|
||||
additional permissions on material, added by you to a covered work,
|
||||
for which you have or can give appropriate copyright permission.
|
||||
|
||||
Notwithstanding any other provision of this License, for material you
|
||||
add to a covered work, you may (if authorized by the copyright holders of
|
||||
that material) supplement the terms of this License with terms:
|
||||
|
||||
a) Disclaiming warranty or limiting liability differently from the
|
||||
terms of sections 15 and 16 of this License; or
|
||||
|
||||
b) Requiring preservation of specified reasonable legal notices or
|
||||
author attributions in that material or in the Appropriate Legal
|
||||
Notices displayed by works containing it; or
|
||||
|
||||
c) Prohibiting misrepresentation of the origin of that material, or
|
||||
requiring that modified versions of such material be marked in
|
||||
reasonable ways as different from the original version; or
|
||||
|
||||
d) Limiting the use for publicity purposes of names of licensors or
|
||||
authors of the material; or
|
||||
|
||||
e) Declining to grant rights under trademark law for use of some
|
||||
trade names, trademarks, or service marks; or
|
||||
|
||||
f) Requiring indemnification of licensors and authors of that
|
||||
material by anyone who conveys the material (or modified versions of
|
||||
it) with contractual assumptions of liability to the recipient, for
|
||||
any liability that these contractual assumptions directly impose on
|
||||
those licensors and authors.
|
||||
|
||||
All other non-permissive additional terms are considered "further
|
||||
restrictions" within the meaning of section 10. If the Program as you
|
||||
received it, or any part of it, contains a notice stating that it is
|
||||
governed by this License along with a term that is a further
|
||||
restriction, you may remove that term. If a license document contains
|
||||
a further restriction but permits relicensing or conveying under this
|
||||
License, you may add to a covered work material governed by the terms
|
||||
of that license document, provided that the further restriction does
|
||||
not survive such relicensing or conveying.
|
||||
|
||||
If you add terms to a covered work in accord with this section, you
|
||||
must place, in the relevant source files, a statement of the
|
||||
additional terms that apply to those files, or a notice indicating
|
||||
where to find the applicable terms.
|
||||
|
||||
Additional terms, permissive or non-permissive, may be stated in the
|
||||
form of a separately written license, or stated as exceptions;
|
||||
the above requirements apply either way.
|
||||
|
||||
8. Termination.
|
||||
|
||||
You may not propagate or modify a covered work except as expressly
|
||||
provided under this License. Any attempt otherwise to propagate or
|
||||
modify it is void, and will automatically terminate your rights under
|
||||
this License (including any patent licenses granted under the third
|
||||
paragraph of section 11).
|
||||
|
||||
However, if you cease all violation of this License, then your
|
||||
license from a particular copyright holder is reinstated (a)
|
||||
provisionally, unless and until the copyright holder explicitly and
|
||||
finally terminates your license, and (b) permanently, if the copyright
|
||||
holder fails to notify you of the violation by some reasonable means
|
||||
prior to 60 days after the cessation.
|
||||
|
||||
Moreover, your license from a particular copyright holder is
|
||||
reinstated permanently if the copyright holder notifies you of the
|
||||
violation by some reasonable means, this is the first time you have
|
||||
received notice of violation of this License (for any work) from that
|
||||
copyright holder, and you cure the violation prior to 30 days after
|
||||
your receipt of the notice.
|
||||
|
||||
Termination of your rights under this section does not terminate the
|
||||
licenses of parties who have received copies or rights from you under
|
||||
this License. If your rights have been terminated and not permanently
|
||||
reinstated, you do not qualify to receive new licenses for the same
|
||||
material under section 10.
|
||||
|
||||
9. Acceptance Not Required for Having Copies.
|
||||
|
||||
You are not required to accept this License in order to receive or
|
||||
run a copy of the Program. Ancillary propagation of a covered work
|
||||
occurring solely as a consequence of using peer-to-peer transmission
|
||||
to receive a copy likewise does not require acceptance. However,
|
||||
nothing other than this License grants you permission to propagate or
|
||||
modify any covered work. These actions infringe copyright if you do
|
||||
not accept this License. Therefore, by modifying or propagating a
|
||||
covered work, you indicate your acceptance of this License to do so.
|
||||
|
||||
10. Automatic Licensing of Downstream Recipients.
|
||||
|
||||
Each time you convey a covered work, the recipient automatically
|
||||
receives a license from the original licensors, to run, modify and
|
||||
propagate that work, subject to this License. You are not responsible
|
||||
for enforcing compliance by third parties with this License.
|
||||
|
||||
An "entity transaction" is a transaction transferring control of an
|
||||
organization, or substantially all assets of one, or subdividing an
|
||||
organization, or merging organizations. If propagation of a covered
|
||||
work results from an entity transaction, each party to that
|
||||
transaction who receives a copy of the work also receives whatever
|
||||
licenses to the work the party's predecessor in interest had or could
|
||||
give under the previous paragraph, plus a right to possession of the
|
||||
Corresponding Source of the work from the predecessor in interest, if
|
||||
the predecessor has it or can get it with reasonable efforts.
|
||||
|
||||
You may not impose any further restrictions on the exercise of the
|
||||
rights granted or affirmed under this License. For example, you may
|
||||
not impose a license fee, royalty, or other charge for exercise of
|
||||
rights granted under this License, and you may not initiate litigation
|
||||
(including a cross-claim or counterclaim in a lawsuit) alleging that
|
||||
any patent claim is infringed by making, using, selling, offering for
|
||||
sale, or importing the Program or any portion of it.
|
||||
|
||||
11. Patents.
|
||||
|
||||
A "contributor" is a copyright holder who authorizes use under this
|
||||
License of the Program or a work on which the Program is based. The
|
||||
work thus licensed is called the contributor's "contributor version".
|
||||
|
||||
A contributor's "essential patent claims" are all patent claims
|
||||
owned or controlled by the contributor, whether already acquired or
|
||||
hereafter acquired, that would be infringed by some manner, permitted
|
||||
by this License, of making, using, or selling its contributor version,
|
||||
but do not include claims that would be infringed only as a
|
||||
consequence of further modification of the contributor version. For
|
||||
purposes of this definition, "control" includes the right to grant
|
||||
patent sublicenses in a manner consistent with the requirements of
|
||||
this License.
|
||||
|
||||
Each contributor grants you a non-exclusive, worldwide, royalty-free
|
||||
patent license under the contributor's essential patent claims, to
|
||||
make, use, sell, offer for sale, import and otherwise run, modify and
|
||||
propagate the contents of its contributor version.
|
||||
|
||||
In the following three paragraphs, a "patent license" is any express
|
||||
agreement or commitment, however denominated, not to enforce a patent
|
||||
(such as an express permission to practice a patent or covenant not to
|
||||
sue for patent infringement). To "grant" such a patent license to a
|
||||
party means to make such an agreement or commitment not to enforce a
|
||||
patent against the party.
|
||||
|
||||
If you convey a covered work, knowingly relying on a patent license,
|
||||
and the Corresponding Source of the work is not available for anyone
|
||||
to copy, free of charge and under the terms of this License, through a
|
||||
publicly available network server or other readily accessible means,
|
||||
then you must either (1) cause the Corresponding Source to be so
|
||||
available, or (2) arrange to deprive yourself of the benefit of the
|
||||
patent license for this particular work, or (3) arrange, in a manner
|
||||
consistent with the requirements of this License, to extend the patent
|
||||
license to downstream recipients. "Knowingly relying" means you have
|
||||
actual knowledge that, but for the patent license, your conveying the
|
||||
covered work in a country, or your recipient's use of the covered work
|
||||
in a country, would infringe one or more identifiable patents in that
|
||||
country that you have reason to believe are valid.
|
||||
|
||||
If, pursuant to or in connection with a single transaction or
|
||||
arrangement, you convey, or propagate by procuring conveyance of, a
|
||||
covered work, and grant a patent license to some of the parties
|
||||
receiving the covered work authorizing them to use, propagate, modify
|
||||
or convey a specific copy of the covered work, then the patent license
|
||||
you grant is automatically extended to all recipients of the covered
|
||||
work and works based on it.
|
||||
|
||||
A patent license is "discriminatory" if it does not include within
|
||||
the scope of its coverage, prohibits the exercise of, or is
|
||||
conditioned on the non-exercise of one or more of the rights that are
|
||||
specifically granted under this License. You may not convey a covered
|
||||
work if you are a party to an arrangement with a third party that is
|
||||
in the business of distributing software, under which you make payment
|
||||
to the third party based on the extent of your activity of conveying
|
||||
the work, and under which the third party grants, to any of the
|
||||
parties who would receive the covered work from you, a discriminatory
|
||||
patent license (a) in connection with copies of the covered work
|
||||
conveyed by you (or copies made from those copies), or (b) primarily
|
||||
for and in connection with specific products or compilations that
|
||||
contain the covered work, unless you entered into that arrangement,
|
||||
or that patent license was granted, prior to 28 March 2007.
|
||||
|
||||
Nothing in this License shall be construed as excluding or limiting
|
||||
any implied license or other defenses to infringement that may
|
||||
otherwise be available to you under applicable patent law.
|
||||
|
||||
12. No Surrender of Others' Freedom.
|
||||
|
||||
If conditions are imposed on you (whether by court order, agreement or
|
||||
otherwise) that contradict the conditions of this License, they do not
|
||||
excuse you from the conditions of this License. If you cannot convey a
|
||||
covered work so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you may
|
||||
not convey it at all. For example, if you agree to terms that obligate you
|
||||
to collect a royalty for further conveying from those to whom you convey
|
||||
the Program, the only way you could satisfy both those terms and this
|
||||
License would be to refrain entirely from conveying the Program.
|
||||
|
||||
13. Use with the GNU Affero General Public License.
|
||||
|
||||
Notwithstanding any other provision of this License, you have
|
||||
permission to link or combine any covered work with a work licensed
|
||||
under version 3 of the GNU Affero General Public License into a single
|
||||
combined work, and to convey the resulting work. The terms of this
|
||||
License will continue to apply to the part which is the covered work,
|
||||
but the special requirements of the GNU Affero General Public License,
|
||||
section 13, concerning interaction through a network will apply to the
|
||||
combination as such.
|
||||
|
||||
14. Revised Versions of this License.
|
||||
|
||||
The Free Software Foundation may publish revised and/or new versions of
|
||||
the GNU General Public License from time to time. Such new versions will
|
||||
be similar in spirit to the present version, but may differ in detail to
|
||||
address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the
|
||||
Program specifies that a certain numbered version of the GNU General
|
||||
Public License "or any later version" applies to it, you have the
|
||||
option of following the terms and conditions either of that numbered
|
||||
version or of any later version published by the Free Software
|
||||
Foundation. If the Program does not specify a version number of the
|
||||
GNU General Public License, you may choose any version ever published
|
||||
by the Free Software Foundation.
|
||||
|
||||
If the Program specifies that a proxy can decide which future
|
||||
versions of the GNU General Public License can be used, that proxy's
|
||||
public statement of acceptance of a version permanently authorizes you
|
||||
to choose that version for the Program.
|
||||
|
||||
Later license versions may give you additional or different
|
||||
permissions. However, no additional obligations are imposed on any
|
||||
author or copyright holder as a result of your choosing to follow a
|
||||
later version.
|
||||
|
||||
15. Disclaimer of Warranty.
|
||||
|
||||
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
|
||||
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
|
||||
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
|
||||
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
|
||||
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
|
||||
IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
|
||||
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
||||
|
||||
16. Limitation of Liability.
|
||||
|
||||
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
|
||||
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
|
||||
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
|
||||
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
|
||||
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
|
||||
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
|
||||
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
|
||||
SUCH DAMAGES.
|
||||
|
||||
17. Interpretation of Sections 15 and 16.
|
||||
|
||||
If the disclaimer of warranty and limitation of liability provided
|
||||
above cannot be given local legal effect according to their terms,
|
||||
reviewing courts shall apply local law that most closely approximates
|
||||
an absolute waiver of all civil liability in connection with the
|
||||
Program, unless a warranty or assumption of liability accompanies a
|
||||
copy of the Program in return for a fee.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
How to Apply These Terms to Your New Programs
|
||||
|
||||
If you develop a new program, and you want it to be of the greatest
|
||||
possible use to the public, the best way to achieve this is to make it
|
||||
free software which everyone can redistribute and change under these terms.
|
||||
|
||||
To do so, attach the following notices to the program. It is safest
|
||||
to attach them to the start of each source file to most effectively
|
||||
state the exclusion of warranty; and each file should have at least
|
||||
the "copyright" line and a pointer to where the full notice is found.
|
||||
|
||||
<one line to give the program's name and a brief idea of what it does.>
|
||||
Copyright (C) <year> <name of author>
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
If the program does terminal interaction, make it output a short
|
||||
notice like this when it starts in an interactive mode:
|
||||
|
||||
<program> Copyright (C) <year> <name of author>
|
||||
This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||
This is free software, and you are welcome to redistribute it
|
||||
under certain conditions; type `show c' for details.
|
||||
|
||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||
parts of the General Public License. Of course, your program's commands
|
||||
might be different; for a GUI interface, you would use an "about box".
|
||||
|
||||
You should also get your employer (if you work as a programmer) or school,
|
||||
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
||||
For more information on this, and how to apply and follow the GNU GPL, see
|
||||
<http://www.gnu.org/licenses/>.
|
||||
|
||||
The GNU General Public License does not permit incorporating your program
|
||||
into proprietary programs. If your program is a subroutine library, you
|
||||
may consider it more useful to permit linking proprietary applications with
|
||||
the library. If this is what you want to do, use the GNU Lesser General
|
||||
Public License instead of this License. But first, please read
|
||||
<http://www.gnu.org/philosophy/why-not-lgpl.html>.
|
||||
8
Binary/Makefile
Normal file
8
Binary/Makefile
Normal file
@@ -0,0 +1,8 @@
|
||||
TOOLS = ../Tools
|
||||
MOREDIFF := $(shell $(TOOLS)/unix/casefn.sh *.img *.rom *.com *.eeprom)
|
||||
SUBDIRS = Apps CPM22 CPM3 QPM ZSDOS ZPM3 CPNET
|
||||
|
||||
include $(TOOLS)/Makefile.inc
|
||||
|
||||
clean::
|
||||
@rm -f *.bin *.com *.img *.rom *.upd *.hex *.pdf *.log *.eeprom *.dat
|
||||
4
Binary/QPM/Clean.cmd
Normal file
4
Binary/QPM/Clean.cmd
Normal file
@@ -0,0 +1,4 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
if exist *.sys del *.sys
|
||||
7
Binary/QPM/Makefile
Normal file
7
Binary/QPM/Makefile
Normal file
@@ -0,0 +1,7 @@
|
||||
TOOLS = ../../Tools
|
||||
MOREDIFF := $(shell $(TOOLS)/unix/casefn.sh *.spr)
|
||||
|
||||
include $(TOOLS)/Makefile.inc
|
||||
|
||||
clean::
|
||||
@rm -f *.sys *.bin
|
||||
21
Binary/QPM/ReadMe.txt
Normal file
21
Binary/QPM/ReadMe.txt
Normal file
@@ -0,0 +1,21 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory contains the QPM 2.7 system files for the RomWBW QPM 2.7
|
||||
adaptation. All of these files are already included on the QPM
|
||||
boot disk images. However if you are creating a QPM boot disk
|
||||
manually, you should copy all of these files to the boot disk.
|
||||
|
||||
Note: Two file have been provided one for RomWBW HBIOS, and one for UNA
|
||||
BIOS. One of these files must be installed on the system boot track.
|
||||
Refer to the QPM Documentation for installing QPM
|
||||
|
||||
These files should also be copied to any QPM boot disks on your
|
||||
system when you upgrade your ROM firmware. Some of these files
|
||||
*must* match the version of the RomWBW firmware you are using for
|
||||
proper operation of your system.
|
||||
194
Binary/ReadMe.txt
Normal file
194
Binary/ReadMe.txt
Normal file
@@ -0,0 +1,194 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory ("Binary") is part of the RomWBW System Software
|
||||
distribution archive. It contains the completed binary outputs of
|
||||
the build process. As described below, these files are used to
|
||||
assemble a working RetroBrew Computers system.
|
||||
|
||||
The files in this directory are created by the build process that is
|
||||
documented in the ReadMe.txt file in the Source directory. When
|
||||
released the directory is populated with the default output files.
|
||||
However, the output of custom builds will be placed in this directory
|
||||
as well.
|
||||
|
||||
If you only see a few files in this directory, then you downloaded
|
||||
just the source from GitHub. To retrieve the full release download
|
||||
package, go to https://github.com/wwarthen/RomWBW. On this page,
|
||||
look for the text "XX releases" where XX is a number. Click on this
|
||||
text to go to the releases page. On this page, you will see the
|
||||
latest releases listed. For each release, you will see a package
|
||||
file called something like "RomWBW-2.9.0-Package.zip". Click on the
|
||||
package file for the release you want to download.
|
||||
|
||||
ROM Firmware Images (<plt>_<cfg>.rom)
|
||||
-------------------------------------
|
||||
|
||||
The files with a ".rom" extension are binary images ready to program
|
||||
into an appropriate PROM. These files are named with the format
|
||||
<plt>_<cfg>.rom. <plt> refers to the primary platform such as Zeta,
|
||||
N8, Mark IV, etc. <cfg> refers to the specific configuration. In
|
||||
general, there will be a standard configuration ("std") for each
|
||||
platform. So, for example, the file called MK4_std.rom is a ROM
|
||||
image for the Mark IV with the standard configuration. If a custom
|
||||
configuration called "custom" is created and built, a new file called
|
||||
MK4_custom.rom will be added to this directory.
|
||||
|
||||
Documentation of the pre-built ROM Images is contained in
|
||||
"RomWBW User Guide.pdf" in the Doc directory.
|
||||
|
||||
ROM Firmware Update Images (<plt>_<cfg>.upd)
|
||||
-------------------------------------
|
||||
|
||||
The files with a ".upd" extension are binary images identical to the
|
||||
.rom files, but they only have the first 128K bytes. The first 128K
|
||||
is the system image without the ROM disk contents. These files can be
|
||||
used to update the system image without modifying the ROM disk
|
||||
contents. Refer to the RomWBW User Guide for more information.
|
||||
|
||||
ROM Executable Images (<plt>_<cfg>.com)
|
||||
---------------------------------------
|
||||
|
||||
When a ROM image (".rom") is created, an executable version of the
|
||||
ROM is also created. These files have the same naming convention as
|
||||
the ROM Image files, but have the extension ".com". These files can
|
||||
be copied to a working system and run like a normal CP/M application.
|
||||
|
||||
When run on the target system, they install in RAM just like they had
|
||||
been loaded from ROM. This allows a new ROM build to be tested
|
||||
without reprogramming the actual ROM.
|
||||
|
||||
WARNING: In a few cases the .com file is too big to load. If you get
|
||||
a message like "Full" or "BAD LOAD" when trying to load one of the
|
||||
.com files, it is too big. In these cases, you will not be able to
|
||||
test the ROM prior to programming it.
|
||||
|
||||
VDU ROM Image (vdu.rom)
|
||||
-----------------------
|
||||
|
||||
The VDU video board requires a dedicated onboard ROM containing the
|
||||
font data. The "vdu.rom" file contains the binary data to program
|
||||
onto that chip.
|
||||
|
||||
Disk Images (fd_*.img, hd_*.img)
|
||||
--------------------------------
|
||||
|
||||
RomWBW includes a mechanism for generating floppy disk and hard disk
|
||||
binary images that are ready to copy directly to a floppy, hard disk,
|
||||
CF Card, or SD Card which will then be ready for use in any
|
||||
RomWBW-based system.
|
||||
|
||||
Essentially, these files contain prepared floppy and hard disk images
|
||||
with a large set of programs and related files. By copying the
|
||||
contents of these files to appropriate media as described below, you
|
||||
can quickly create ready-to-use media. Win32DiskImager or
|
||||
RawWriteWin can be used to copy images directly to media. These
|
||||
programs are included in the RomWBW Tools directory.
|
||||
|
||||
The fd_*.img files are floppy disk images. They are sized for 1.44MB
|
||||
floppy media and can be copied to actual floppy disks using
|
||||
RawWriteWin (as long as you have access to a floppy drive on your
|
||||
Windows computer). The resulting floppy disks will be usable on any
|
||||
RomWBW-based system with floppy drive(s).
|
||||
|
||||
Likewise, the hd512_*.img and hd1k_*.img files are hard disk images.
|
||||
Each file is intended to be copied to the start of any type of hard
|
||||
disk media (typically a CF Card or SD Card). The resulting media will
|
||||
be usable on any RomWBW-based system that accepts the corresponding
|
||||
media type.
|
||||
|
||||
NOTE: The hd512_*.img files are equivalent to the hd_*.img
|
||||
files in previous distributions. The hd1k_*.img files
|
||||
contained a revised file system format that increases the
|
||||
maximum number of CP/M directory entries from 512 to 1024.
|
||||
Refer to the ReadMe.txt in the Source/Images directory
|
||||
for details.
|
||||
|
||||
Documentation of the pre-built disk images is contained in the
|
||||
"RomWBW User Guide" found in the Doc directory. The contents of
|
||||
the disk images is contained in the "RomWBW Disk Catalog", but it
|
||||
is significantly out-of-date.
|
||||
|
||||
The contents of the floppy/hard disk images are created by
|
||||
the BuildImages.cmd script in the Source directory. Additional
|
||||
information on how to generate custom disk images is found in the
|
||||
Source\Images ReadMe.txt file.
|
||||
|
||||
Disk Images (hd512_combo.img, hd1k_combo.img, *_std_hd1k_combo.img)
|
||||
-------------------------------------------------------------------
|
||||
|
||||
The hd512_combo.img and hd1k_combo.img file are the primary combo
|
||||
disk image files suitable for most platforms.
|
||||
|
||||
The *_std_hd1k_combo.img files are platform specific combo files
|
||||
typically used in romless platforms, they also contain RomWBW binary code
|
||||
that is loaded at boot time into RAM
|
||||
|
||||
Disk Images (hd1k_prefix.dat, *_std_hd1k_prefix.dat)
|
||||
----------------------------------------------------
|
||||
|
||||
The hd1k_prefix.dat file is part of the combo disk images and is
|
||||
applied to hd1k image files as a prefix, it contains the standard
|
||||
partion table.
|
||||
|
||||
The *_std_hd1k_prefix.dat files are platform specific prefixes
|
||||
typically used in romless platforms, they also contain RomWBW binary code
|
||||
that is loaded at boot time into RAM
|
||||
|
||||
Disk Images (psys.img)
|
||||
----------------------
|
||||
|
||||
The psys.img file contains a full implementation of the UCSD p-System
|
||||
for the Z80 running under RomWBW. This image file must be placed on
|
||||
disk media by itself (not appended or concatenated with hd*.img files.
|
||||
Refer to the Source/pSys/ReadMe.txt file for more information on the
|
||||
p-System implementation.
|
||||
|
||||
Propeller ROM Images (*.eeprom)
|
||||
-------------------------------
|
||||
|
||||
The files with and extension of ".eeprom" contain the binary images
|
||||
to be programmed into the Propeller-based boards. The list below
|
||||
indicates which file targets each of the Propeller board variants:
|
||||
|
||||
ParPortProp ParPortProp.eeprom
|
||||
PropIO V1 PropIO.eeprom
|
||||
PropIO V2 PropIO2.eeprom
|
||||
|
||||
Refer to the board documentation of the boards for more information
|
||||
on how to program the EEPROMs on these boards.
|
||||
|
||||
SUB DIRECTORIES
|
||||
===============
|
||||
|
||||
Apps Directory
|
||||
--------------
|
||||
|
||||
The Apps subdirectory contains the executable application files that
|
||||
are specific to RomWBW. The source for these applications is found
|
||||
in the Source\Apps directory of the distribution.
|
||||
|
||||
CPNET Directory
|
||||
---------------
|
||||
|
||||
This directory contains the CP/NET client packages. Please refer to
|
||||
the RomWBW User Guide for instructions on installing these packages,
|
||||
or see the Readme.txt file in this sub-directory
|
||||
|
||||
CPM22 CPM3 ZSDOS ZPM3 QPM Directories
|
||||
-------------------------------------
|
||||
|
||||
These directories contains the system files for the RomWBW adaptations
|
||||
for each operating system. All of these files are already included on
|
||||
the boot disk images. However if you are creating a o/s boot disk
|
||||
manually, you will need copy all of these files to the boot disk.
|
||||
|
||||
These files should also be copied to any boot disks on your
|
||||
system when you upgrade your ROM firmware. Some of these files
|
||||
*must* match the version of the RomWBW firmware you are using for
|
||||
proper operation of your system.
|
||||
10
Binary/ZPM3/Clean.cmd
Normal file
10
Binary/ZPM3/Clean.cmd
Normal file
@@ -0,0 +1,10 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
if exist *.spr del *.spr
|
||||
if exist *.com del *.com
|
||||
if exist *.sys del *.sys
|
||||
if exist *.pat del *.pat
|
||||
if exist *.dat del *.dat
|
||||
if exist *.zpm del *.zpm
|
||||
if exist *.spr del *.spr
|
||||
7
Binary/ZPM3/Makefile
Normal file
7
Binary/ZPM3/Makefile
Normal file
@@ -0,0 +1,7 @@
|
||||
TOOLS = ../../Tools
|
||||
MOREDIFF := $(shell $(TOOLS)/unix/casefn.sh *.spr)
|
||||
|
||||
include $(TOOLS)/Makefile.inc
|
||||
|
||||
clean::
|
||||
@rm -f *.spr *.com *.sys *.dat *.zpm
|
||||
17
Binary/ZPM3/ReadMe.txt
Normal file
17
Binary/ZPM3/ReadMe.txt
Normal file
@@ -0,0 +1,17 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory contains the ZPM3 system files for the RomWBW ZPM3
|
||||
adaptation. All of these files are already included on the ZPM3
|
||||
boot disk images. However if you are creating a CP/M 3 boot disk
|
||||
manually, you should copy all of these files to the boot disk.
|
||||
|
||||
These files should also be copied to any ZPM3 boot disks on your
|
||||
system when you upgrade your ROM firmware. Some of these files
|
||||
*must* match the version of the RomWBW firmware you are using for
|
||||
proper operation of your system.
|
||||
4
Binary/ZSDOS/Clean.cmd
Normal file
4
Binary/ZSDOS/Clean.cmd
Normal file
@@ -0,0 +1,4 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
if exist *.sys del *.sys
|
||||
7
Binary/ZSDOS/Makefile
Normal file
7
Binary/ZSDOS/Makefile
Normal file
@@ -0,0 +1,7 @@
|
||||
TOOLS = ../../Tools
|
||||
MOREDIFF := $(shell $(TOOLS)/unix/casefn.sh *.spr)
|
||||
|
||||
include $(TOOLS)/Makefile.inc
|
||||
|
||||
clean::
|
||||
@rm -f *.sys
|
||||
23
Binary/ZSDOS/ReadMe.txt
Normal file
23
Binary/ZSDOS/ReadMe.txt
Normal file
@@ -0,0 +1,23 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory contains the ZSDOS system files for the RomWBW ZSDOS
|
||||
adaptation. All of these files are already included on the ZSDOS
|
||||
boot disk images. However if you are creating a ZSDOS boot disk
|
||||
manually, you should copy all of these files to the boot disk.
|
||||
|
||||
Note: Two file have been provided one for RomWBW HBIOS, and one for UNA
|
||||
BIOS. One of these files must be installed on the system boot track.
|
||||
This is usually achieved by the SYSCOPY utility e.g.
|
||||
|
||||
SYSCOPY a:=zsys_wbw.sys
|
||||
|
||||
These files should also be copied to any ZSDOS boot disks on your
|
||||
system when you upgrade your ROM firmware. Some of these files
|
||||
*must* match the version of the RomWBW firmware you are using for
|
||||
proper operation of your system.
|
||||
@@ -1,4 +1,6 @@
|
||||
@echo off
|
||||
setlocal
|
||||
cd Source
|
||||
PowerShell .\Build.ps1 %*
|
||||
|
||||
pushd Source && call Build %* || exit /b & popd
|
||||
|
||||
if "%*" == "" pause
|
||||
|
||||
@@ -1,7 +0,0 @@
|
||||
@echo off
|
||||
|
||||
setlocal
|
||||
|
||||
echo Building Apps...
|
||||
cd Apps
|
||||
call Build.cmd
|
||||
@@ -1,7 +0,0 @@
|
||||
@echo off
|
||||
|
||||
setlocal
|
||||
|
||||
echo Building CP/M 2.2...
|
||||
cd CPM22
|
||||
call Build.cmd
|
||||
@@ -1,7 +0,0 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
call BuildCPM22
|
||||
call BuildZCPR
|
||||
call BuildZCPR-DJ
|
||||
call BuildApps.cmd
|
||||
@@ -1,4 +0,0 @@
|
||||
@echo off
|
||||
setlocal
|
||||
cd Source
|
||||
PowerShell .\BuildUNA.ps1 %*
|
||||
@@ -1,4 +0,0 @@
|
||||
@echo off
|
||||
setlocal
|
||||
cd Source
|
||||
PowerShell .\BuildUNALOAD.ps1 %*
|
||||
@@ -1,7 +0,0 @@
|
||||
@echo off
|
||||
|
||||
setlocal
|
||||
|
||||
echo Building ZCPR-DJ...
|
||||
cd ZCPR-DJ
|
||||
call Build.cmd
|
||||
@@ -1,7 +0,0 @@
|
||||
@echo off
|
||||
|
||||
setlocal
|
||||
|
||||
echo Building ZCPR...
|
||||
cd ZCPR
|
||||
call Build.cmd
|
||||
128
CODE_OF_CONDUCT.md
Normal file
128
CODE_OF_CONDUCT.md
Normal file
@@ -0,0 +1,128 @@
|
||||
# Contributor Covenant Code of Conduct
|
||||
|
||||
## Our Pledge
|
||||
|
||||
We as members, contributors, and leaders pledge to make participation in our
|
||||
community a harassment-free experience for everyone, regardless of age, body
|
||||
size, visible or invisible disability, ethnicity, sex characteristics, gender
|
||||
identity and expression, level of experience, education, socio-economic status,
|
||||
nationality, personal appearance, race, religion, or sexual identity
|
||||
and orientation.
|
||||
|
||||
We pledge to act and interact in ways that contribute to an open, welcoming,
|
||||
diverse, inclusive, and healthy community.
|
||||
|
||||
## Our Standards
|
||||
|
||||
Examples of behavior that contributes to a positive environment for our
|
||||
community include:
|
||||
|
||||
* Demonstrating empathy and kindness toward other people
|
||||
* Being respectful of differing opinions, viewpoints, and experiences
|
||||
* Giving and gracefully accepting constructive feedback
|
||||
* Accepting responsibility and apologizing to those affected by our mistakes,
|
||||
and learning from the experience
|
||||
* Focusing on what is best not just for us as individuals, but for the
|
||||
overall community
|
||||
|
||||
Examples of unacceptable behavior include:
|
||||
|
||||
* The use of sexualized language or imagery, and sexual attention or
|
||||
advances of any kind
|
||||
* Trolling, insulting or derogatory comments, and personal or political attacks
|
||||
* Public or private harassment
|
||||
* Publishing others' private information, such as a physical or email
|
||||
address, without their explicit permission
|
||||
* Other conduct which could reasonably be considered inappropriate in a
|
||||
professional setting
|
||||
|
||||
## Enforcement Responsibilities
|
||||
|
||||
Community leaders are responsible for clarifying and enforcing our standards of
|
||||
acceptable behavior and will take appropriate and fair corrective action in
|
||||
response to any behavior that they deem inappropriate, threatening, offensive,
|
||||
or harmful.
|
||||
|
||||
Community leaders have the right and responsibility to remove, edit, or reject
|
||||
comments, commits, code, wiki edits, issues, and other contributions that are
|
||||
not aligned to this Code of Conduct, and will communicate reasons for moderation
|
||||
decisions when appropriate.
|
||||
|
||||
## Scope
|
||||
|
||||
This Code of Conduct applies within all community spaces, and also applies when
|
||||
an individual is officially representing the community in public spaces.
|
||||
Examples of representing our community include using an official e-mail address,
|
||||
posting via an official social media account, or acting as an appointed
|
||||
representative at an online or offline event.
|
||||
|
||||
## Enforcement
|
||||
|
||||
Instances of abusive, harassing, or otherwise unacceptable behavior may be
|
||||
reported to the community leaders responsible for enforcement at
|
||||
wwarthen@gmail.com.
|
||||
All complaints will be reviewed and investigated promptly and fairly.
|
||||
|
||||
All community leaders are obligated to respect the privacy and security of the
|
||||
reporter of any incident.
|
||||
|
||||
## Enforcement Guidelines
|
||||
|
||||
Community leaders will follow these Community Impact Guidelines in determining
|
||||
the consequences for any action they deem in violation of this Code of Conduct:
|
||||
|
||||
### 1. Correction
|
||||
|
||||
**Community Impact**: Use of inappropriate language or other behavior deemed
|
||||
unprofessional or unwelcome in the community.
|
||||
|
||||
**Consequence**: A private, written warning from community leaders, providing
|
||||
clarity around the nature of the violation and an explanation of why the
|
||||
behavior was inappropriate. A public apology may be requested.
|
||||
|
||||
### 2. Warning
|
||||
|
||||
**Community Impact**: A violation through a single incident or series
|
||||
of actions.
|
||||
|
||||
**Consequence**: A warning with consequences for continued behavior. No
|
||||
interaction with the people involved, including unsolicited interaction with
|
||||
those enforcing the Code of Conduct, for a specified period of time. This
|
||||
includes avoiding interactions in community spaces as well as external channels
|
||||
like social media. Violating these terms may lead to a temporary or
|
||||
permanent ban.
|
||||
|
||||
### 3. Temporary Ban
|
||||
|
||||
**Community Impact**: A serious violation of community standards, including
|
||||
sustained inappropriate behavior.
|
||||
|
||||
**Consequence**: A temporary ban from any sort of interaction or public
|
||||
communication with the community for a specified period of time. No public or
|
||||
private interaction with the people involved, including unsolicited interaction
|
||||
with those enforcing the Code of Conduct, is allowed during this period.
|
||||
Violating these terms may lead to a permanent ban.
|
||||
|
||||
### 4. Permanent Ban
|
||||
|
||||
**Community Impact**: Demonstrating a pattern of violation of community
|
||||
standards, including sustained inappropriate behavior, harassment of an
|
||||
individual, or aggression toward or disparagement of classes of individuals.
|
||||
|
||||
**Consequence**: A permanent ban from any sort of public interaction within
|
||||
the community.
|
||||
|
||||
## Attribution
|
||||
|
||||
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
|
||||
version 2.0, available at
|
||||
https://www.contributor-covenant.org/version/2/0/code_of_conduct.html.
|
||||
|
||||
Community Impact Guidelines were inspired by [Mozilla's code of conduct
|
||||
enforcement ladder](https://github.com/mozilla/diversity).
|
||||
|
||||
[homepage]: https://www.contributor-covenant.org
|
||||
|
||||
For answers to common questions about this code of conduct, see the FAQ at
|
||||
https://www.contributor-covenant.org/faq. Translations are available at
|
||||
https://www.contributor-covenant.org/translations.
|
||||
42
CONTRIBUTING.md
Normal file
42
CONTRIBUTING.md
Normal file
@@ -0,0 +1,42 @@
|
||||
# Contributing to RomWBW
|
||||
|
||||
> **WARNING**: The `dev` branch of RomWBW has been deprecated as of v3.4. All Pull Requests should now target the `master` branch.
|
||||
|
||||
Contributions of all kinds to RomWBW are welcomed and greatly appreciated.
|
||||
|
||||
- Reporting bug(s) and suggesting new feature(s)
|
||||
- Discussing the current state of the code
|
||||
- Submitting a fixes and enhancements
|
||||
|
||||
## RomWBW GitHub Repository
|
||||
|
||||
The [RomWBW GitHub Repository](https://github.com/wwarthen/RomWBW) is the primary location for developing, supporting, and distributing RomWBW. Although input is gladly accepted from almost any channel, the GitHub Repository is preferred.
|
||||
|
||||
- Use **Issues** to report bugs, request enhancements, or ask usage questions.
|
||||
- Use **Discussions** to interact with others
|
||||
- Use **Pull Requests** to submit content (code, documentation, etc.)
|
||||
|
||||
## Submitting Content
|
||||
|
||||
This RomWBW Project uses the standard [GitHub Flow](https://docs.github.com/en/get-started/quickstart/github-flow). Submission of content changes (including code) are ideally done via Pull Requests.
|
||||
|
||||
- Submitters are advised to contact [Wayne Warthen](mailto:wwarthen@gmail.com) or start a GitHub Discussion prior to starting any significant work. This is simply to ensure that submissions are consistent
|
||||
with the overall goals and intentions of RomWBW.
|
||||
- All submissions should be based on the `master` branch. To create your submission, fork the RomWBW repository and create your branch from `master`. Make (and test) your changes in your personal fork.
|
||||
- Please update relevant documentation and the `ChangeLog` found in the `Doc` folder.
|
||||
- You are encouraged to comment your submissions to ensure your work is properly attributed.
|
||||
- When ready, submit a Pull Request to merge your forked branch into the RomWBW master branch.
|
||||
|
||||
## Coding Style
|
||||
|
||||
Due to the nature of the project, you will find a variety of coding styles. When making changes to existing code, please try to be consistent with the existing coding style. You may not like the current style, but no one likes mixed styles
|
||||
in one file/module.
|
||||
|
||||
Be careful with white space. RomWBW is primarily assembly langauge code. The use of tab stops at every 8 characters is pretty standard for assembler. If you use something else, then your code will look odd when viewed by others.
|
||||
|
||||
In most cases, the use of `<cr><lf>` line endings is preferred. This is standard for the operating systems of the era that RomWBW provides. Also note that CP/M text files should end with a ctrl-Z (0x1A). This is not magically added by the
|
||||
tools that generate the disk images.
|
||||
|
||||
## License
|
||||
|
||||
RomWBW is licensed under GPLv3. When you submit code changes, your submissions are understood to be under the same [GPLv3 License](https://www.gnu.org/licenses/gpl-3.0.html) that covers the project.
|
||||
@@ -1,72 +0,0 @@
|
||||
@echo off
|
||||
|
||||
setlocal
|
||||
|
||||
set PATH=..\Tools\tasm32;..\Tools\zx;%PATH%
|
||||
|
||||
set TASMTABS=..\Tools\tasm32
|
||||
|
||||
set ZXBINDIR=../tools/cpm/bin/
|
||||
set ZXLIBDIR=../tools/cpm/lib/
|
||||
set ZXINCDIR=../tools/cpm/include/
|
||||
|
||||
call :asm ccpb03 || goto :eof
|
||||
call :asm bdosb01 || goto :eof
|
||||
|
||||
zx MAC -CCP.ASM -$PO
|
||||
zx MLOAD25 -CCP.BIN=CCP.HEX
|
||||
|
||||
zx MAC -BDOS.ASM -$PO
|
||||
zx MLOAD25 -BDOS.BIN=BDOS.HEX
|
||||
|
||||
zx MAC -CCP22.ASM -$PO
|
||||
zx MLOAD25 -CCP22.BIN=CCP22.HEX
|
||||
|
||||
zx MAC -BDOS22.ASM -$PO
|
||||
zx MLOAD25 -BDOS22.BIN=BDOS22.HEX
|
||||
|
||||
zx MAC -OS2CCP.ASM -$PO
|
||||
zx MLOAD25 -OS2CCP.BIN=OS2CCP.HEX
|
||||
|
||||
zx MAC -OS3BDOS.ASM -$PO
|
||||
zx MLOAD25 -OS3BDOS.BIN=OS3BDOS.HEX
|
||||
|
||||
goto :eof
|
||||
|
||||
:asm
|
||||
echo.
|
||||
echo Building %1...
|
||||
tasm -t80 -b -g3 -fFF %1.asm %1.bin %1.lst
|
||||
goto :eof
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@echo off
|
||||
|
||||
setlocal
|
||||
|
||||
set PATH=..\Tools\tasm32;..\Tools\zx;%PATH%
|
||||
|
||||
set TASMTABS=..\Tools\tasm32
|
||||
|
||||
set ZXBINDIR=../tools/cpm/bin/
|
||||
set ZXLIBDIR=../tools/cpm/lib/
|
||||
set ZXINCDIR=../tools/cpm/include/
|
||||
|
||||
call :asm SysCopy || goto :eof
|
||||
call :asm Assign || goto :eof
|
||||
call :asm Format || goto :eof
|
||||
call :asm Talk || goto :eof
|
||||
|
||||
zx Z80ASM -SYSGEN/F
|
||||
|
||||
goto :eof
|
||||
|
||||
:asm
|
||||
echo.
|
||||
echo Building %1...
|
||||
tasm -t80 -b -g3 -fFF %1.asm %1.com %1.lst
|
||||
goto :eof
|
||||
@@ -1,5 +0,0 @@
|
||||
@echo off
|
||||
if exist *.bin del *.bin
|
||||
if exist *.lst del *.lst
|
||||
if exist *.prn del *.prn
|
||||
if exist *.hex del *.hex
|
||||
36
Clean.cmd
36
Clean.cmd
@@ -1,37 +1,5 @@
|
||||
@echo off
|
||||
setlocal
|
||||
|
||||
echo Cleaning Source...
|
||||
pushd Source
|
||||
call Clean.cmd
|
||||
popd
|
||||
|
||||
echo Cleaning Apps...
|
||||
pushd Apps
|
||||
call Clean.cmd
|
||||
popd
|
||||
|
||||
echo Cleaning CPM22...
|
||||
pushd CPM22
|
||||
call Clean.cmd
|
||||
popd
|
||||
|
||||
echo Cleaning ZCPR...
|
||||
pushd ZCPR
|
||||
call Clean.cmd
|
||||
popd
|
||||
|
||||
echo Cleaning ZCPR-DJ...
|
||||
pushd ZCPR-DJ
|
||||
call Clean.cmd
|
||||
popd
|
||||
|
||||
if exist *.img del *.img /Q
|
||||
if exist debug.log del debug.log
|
||||
|
||||
choice /m "Clean Output directories?"
|
||||
if errorlevel 2 goto :eof
|
||||
echo Cleaning Output directories...
|
||||
if exist Output\*.* del Output\*.* /Q
|
||||
if exist OutputUNA\*.* del OutputUNA\*.* /Q
|
||||
if exist OutputUNALOAD\*.* del OutputUNALOAD\*.* /Q
|
||||
pushd Binary && call Clean || exit /b 1 & popd
|
||||
pushd Source && call Clean || exit /b 1 & popd
|
||||
|
||||
348
Doc/Build.txt
348
Doc/Build.txt
@@ -1,348 +0,0 @@
|
||||
Building a Custom ROM
|
||||
---------------------
|
||||
|
||||
At present, the build environment assumes you are running
|
||||
a current version of Microsoft Windows (either 32-bit or
|
||||
64-bit).
|
||||
|
||||
If you are using Linux, David Giles has contributed a Linux
|
||||
makefile that should work for you. Please read the
|
||||
LinuxBuild.txt file for more information.
|
||||
|
||||
All required tools are included in the distribution. You
|
||||
should not need anything other than what comes as part of
|
||||
Windows or as part of the distribution.
|
||||
|
||||
In summary, the process involves the 4 steps below:
|
||||
|
||||
1) Create/update configuration file
|
||||
|
||||
2) Update/Add/Delete any files you want incorporated in
|
||||
the ROM Disk
|
||||
|
||||
3) Run the build script (or makefile if you prefer) and
|
||||
confirm there are no errors.
|
||||
|
||||
4) Burn the resultant ROM image and try it.
|
||||
|
||||
The process is really very simple. In fact, you can
|
||||
essentially skip steps 1 & 2 if you want to try simply
|
||||
building one of the existing configurations.
|
||||
|
||||
Each of the 4 steps above is described in more detail
|
||||
below.
|
||||
|
||||
1. Create/Update Configuration File
|
||||
-----------------------------------
|
||||
|
||||
The settings for a build are primarily controled by
|
||||
a configuration file that is included in the build
|
||||
process. In order to customize your settings, you
|
||||
need to modify an existing configuration file or
|
||||
create your own.
|
||||
|
||||
If you look in the Source directory, you will see
|
||||
a series of files named config_xxxx_yyyy.asm. Each of
|
||||
them corresponds to one of the standard configurations
|
||||
listed in the ROMList.txt file.
|
||||
|
||||
You have two choices. You can simply modify the existing
|
||||
configuration file that is closest to your situation, or
|
||||
you can copy it to a new config_xxxx_yyyy.asm file and modify
|
||||
that. I recommend that you copy one to your own name so
|
||||
that you will always have the unmodified standard configuration
|
||||
files left in place. So, for example, you could just
|
||||
copy config_ZETA_std.asm to config_ZETA_wayne.asm. You MUST
|
||||
name your config file as config_xxxx_yyyy.asm. The xxxx's
|
||||
must match your platform (N8VEM, ZETA, N8, S2I, or S100).
|
||||
The yyyy's can be whatever you want.
|
||||
|
||||
The config files are simply text files with various
|
||||
settings. Open your target config file with your
|
||||
favorite text editor and modify the settings as desired.
|
||||
|
||||
Unfortunately, I have not yet documented each of the
|
||||
settings in detail; that will be a separate document
|
||||
provided in the future. However, there are comments
|
||||
in the config file that will probably be sufficient
|
||||
for the most part.
|
||||
|
||||
2. Update/Add/Delete ROM Disk Files
|
||||
-----------------------------------
|
||||
|
||||
The files that are included on the ROM Disk of your
|
||||
ROM are copied from a set of directories during the
|
||||
build process. This allows you to have complete
|
||||
flexibility over the files you want included in your
|
||||
ROM.
|
||||
|
||||
If you look at the RomDsk directory, you will see
|
||||
a variety of subdirectories. These subdirectories
|
||||
contain the files that will be included in the
|
||||
ROM disk. The build process will determine
|
||||
which subdirectories to include files from based
|
||||
on the following rules:
|
||||
|
||||
First, all files from either std_512 or std_1024 will
|
||||
be incuded depending on on the size of the ROM you
|
||||
are building. If you are building a 512KB ROM, then
|
||||
all the files from std_512KB will be included. If you
|
||||
are building a 1MB ROM, then all the files from std_1024KB
|
||||
will be included. Essentialy, the files in std_1204KB are
|
||||
a superset of the ones in std_512KB because there is more
|
||||
space available for the ROM drive.
|
||||
|
||||
Second, all files from the directory that corresponds to
|
||||
your configuration file will be included. If you build
|
||||
the "ZETA_std" configuration, all files in cfg_ZETA_std will
|
||||
be added. Note that these files will be in addition
|
||||
to the files from the std_XXXKB directory.
|
||||
|
||||
If you created your own config file (like config_ZETA_wayne.asm
|
||||
described above), you MUST create a subdirectory within
|
||||
the RomDsk directory and populate it with the files
|
||||
you want added. Normally, you would include the
|
||||
files from the original standard config. So, if
|
||||
you created config_ZETA_wayne.asm from config_ZETA_std.asm,
|
||||
then you would create a subdirectory in RomDsk called
|
||||
cfg_ZETA_wayne and copy all the files from cfg_ZETA_std to
|
||||
cfg_ZETA_wayne.
|
||||
|
||||
3. Run the Build Process
|
||||
------------------------
|
||||
|
||||
NOTE: The process described here is the more commonly
|
||||
used build script. If you wish to use a makefile
|
||||
instead, refer to the comments in the makefile in
|
||||
the Source directory as an alternative to the
|
||||
process described here.
|
||||
|
||||
The build involves running commands at the command
|
||||
prompt. From a Command Prompt window, you will need
|
||||
to change to the high level directory for the build.
|
||||
Normally, you would be changing to the RomWBW directory
|
||||
unless you renamed it.
|
||||
|
||||
First, you will need to build the components that are
|
||||
common to all configurations. These components do not
|
||||
require any configuration. To build these, use the
|
||||
following commands and ensure that they complete
|
||||
without error:
|
||||
|
||||
BuildZCPR-DJ
|
||||
BuildApps2
|
||||
|
||||
To run the main build and be prompted for required information,
|
||||
just enter "Build". You will be prompted for the information
|
||||
described below and the build should run. If an error is
|
||||
encountered, the build should stop and display an error
|
||||
in red text.
|
||||
|
||||
If you immediately receive the error "the execution of
|
||||
scripts is disabled on this system", then you will need to
|
||||
change the PowerShell Execution-Polcy to "RemoteSigned".
|
||||
To do this, you need to right-click on FixPowerShell.cmd and
|
||||
choose "Run as Administrator" to make the change. If is
|
||||
critical that you right-click and use "Run as Administrator"
|
||||
or the change will not work (you will get an error
|
||||
indicating "Access to the registry denied" if you fail to
|
||||
use "Run as Administrator".
|
||||
|
||||
The build script will prompt you for the following information
|
||||
which you will need to provide (don't worry, it is simple):
|
||||
|
||||
Platform:
|
||||
|
||||
Respond with the name of the platform that you are targeting.
|
||||
It must be one of N8VEM, ZETA, N8, S2I, or S100.
|
||||
|
||||
Configuration:
|
||||
|
||||
Respond with the name of the configuration you wish to build.
|
||||
A list of all available configurations is displayed for your
|
||||
convenience. For example, if you are building the provided
|
||||
ZETA_std configuration, just enter "std". If you have created a
|
||||
custom configuration as described above, you would enter
|
||||
"wayne".
|
||||
|
||||
ROM Size [512|1024]:
|
||||
|
||||
Respond with either "512" for a 512KB ROM build or "1024" for a
|
||||
1MB ROM build. Only the two choices are possible at this time.
|
||||
It is important that you choose a ROM size that is no larger than
|
||||
the szie of the ROM you will ultimately be burning. This is
|
||||
dependant on your hardware.
|
||||
|
||||
System [CPM|ZSYS]:
|
||||
|
||||
Respond with the type of system you wish to create. If you are
|
||||
not sure which you want, you should enter "CPM". Refer to the
|
||||
ReadMe.txt file for more information on the difference between
|
||||
the two system types.
|
||||
|
||||
At this point, the build should run and you will see output related
|
||||
to the assembler runs and some utility invocations. Just review
|
||||
the output for any obvioius errors. Normally, all errors will
|
||||
cause the build to stop immediately and display an error message
|
||||
in red.
|
||||
|
||||
You will see some lines in the output indicating the amount of
|
||||
space variouis components have taken. You should check these
|
||||
to make sure you do not see any negative numbers which would
|
||||
indicate that you have included too many features/drivers for
|
||||
the available memory space. Here are examples of the lines
|
||||
showing the space used:
|
||||
|
||||
DATA space remaining: 39 bytes.
|
||||
BOOT LOADER space remaining: 3503 bytes.
|
||||
CBIOS space remaining: 161 bytes.
|
||||
DBGMON space remaining: 860 bytes.
|
||||
ROMX space remaining: 8191 bytes.
|
||||
BOOT LOADER space remaining: 3503 bytes.
|
||||
|
||||
4. Deploy the ROM
|
||||
-----------------
|
||||
|
||||
If you look in the Output directory. You should find the following files:
|
||||
|
||||
<config>.rom - binary ROM image to burn to EEPROM
|
||||
<config>.sys - system image that can be written to the start of a
|
||||
disk to enable boot from disk functionality
|
||||
<config>.com - executable version of the system image that can be
|
||||
copied via xmodem to a running system to test
|
||||
the build.
|
||||
|
||||
The actual ROM image is the file ending in .rom. It should be exactly
|
||||
512KB or 1MB depending on the ROM size you chose. Simply burn the .rom
|
||||
image to your ROM and install it in your hardware.
|
||||
|
||||
Specifying Build Options on Command Line
|
||||
----------------------------------------
|
||||
|
||||
If you don't want to be prompted for the options to the "Build"
|
||||
command, you can specify the options right on the command line.
|
||||
|
||||
For example:
|
||||
|
||||
Build ZETA std 512 CPM
|
||||
|
||||
In this case, you will not be prompted. This is useful if you
|
||||
wish to automate your build process.
|
||||
|
||||
Example Build Run
|
||||
-----------------
|
||||
|
||||
C:\Users\WWarthen\Projects\N8VEM\Build\RomWBW>Build.cmd
|
||||
Platform [N8VEM|ZETA|N8|S2I|S100]: ZETA
|
||||
Configurations available:
|
||||
> ppp
|
||||
> std
|
||||
Configuration: std
|
||||
ROM Size [512|1024]: 512
|
||||
System [CPM|ZSYS]: CPM
|
||||
|
||||
Building ZETA_std: 512KB ROM configuration std for Z80...
|
||||
|
||||
tasm -t80 -g3 ccpb03.asm cp.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 bdosb01.asm dos.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 syscfg.asm syscfg.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
Configuration: ZETA Z80 SBC, FLOPPY (AUTOSIZE), PPIDE (STD)
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 -dBLD_SYS=SYS_CPM cbios.asm cbios.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
Configuration: ZETA Z80 SBC, FLOPPY (AUTOSIZE), PPIDE (STD)
|
||||
INFOLIST occupies 18 bytes.
|
||||
UTIL occupies 484 bytes.
|
||||
FD_DATA occupies 340 bytes.
|
||||
PPIDE_DATA occupies 1116 bytes.
|
||||
CBIOS space remaining: 2092 bytes.
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 dbgmon.asm dbgmon.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
Configuration: ZETA Z80 SBC, FLOPPY (AUTOSIZE), PPIDE (STD)
|
||||
DBGMON space remaining: 795 bytes.
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 prefix.asm prefix.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
Configuration: ZETA Z80 SBC, FLOPPY (AUTOSIZE), PPIDE (STD)
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 bootrom.asm bootrom.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
Configuration: ZETA Z80 SBC, FLOPPY (AUTOSIZE), PPIDE (STD)
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 bootapp.asm bootapp.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
Configuration: ZETA Z80 SBC, FLOPPY (AUTOSIZE), PPIDE (STD)
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 loader.asm loader.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
Configuration: ZETA Z80 SBC, FLOPPY (AUTOSIZE), PPIDE (STD)
|
||||
LOADER space remaining: 1205 bytes.
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 pgzero.asm pgzero.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 hbios.asm hbios.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
Configuration: ZETA Z80 SBC, FLOPPY (AUTOSIZE), PPIDE (STD)
|
||||
UART occupies 146 bytes.
|
||||
FD occupies 2071 bytes.
|
||||
PPIDE occupies 809 bytes.
|
||||
HBIOS space remaining: 24428 bytes.
|
||||
STACK space remaining: 145 bytes.
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 hbfill.asm hbfill.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
Configuration: ZETA Z80 SBC, FLOPPY (AUTOSIZE), PPIDE (STD)
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
tasm -t80 -g3 romfill.asm romfill.bin
|
||||
TASM Z80 Assembler. Version 3.2 September, 2001.
|
||||
Copyright (C) 2001 Squak Valley Software
|
||||
tasm: pass 1 complete.
|
||||
tasm: pass 2 complete.
|
||||
tasm: Number of errors = 0
|
||||
Building ZETA_std output files...
|
||||
Building 512KB ZETA_std ROM disk data file...
|
||||
|
||||
C:\Users\WWarthen\Projects\N8VEM\Build\RomWBW>
|
||||
81
Doc/CPM/BPBIOS/BPBIOS_1_Introduction.md
Normal file
81
Doc/CPM/BPBIOS/BPBIOS_1_Introduction.md
Normal file
@@ -0,0 +1,81 @@
|
||||
# B/P Bios
|
||||
# Banked and Portable Basic IO System
|
||||
|
||||
# 1 Introduction
|
||||
|
||||
The Banked and Portable (B/P) Basic I/O System (BIOS) is an effort to standardize many of the logical to physical mapping mechanisms on Microcomputers running Z-Systems with ZSDOS. In expanding the capabilities of such systems, it became apparent that standard BIOSes do not contain the functionality necessary, adequate standardization in extended BIOS calls, nor an internal structure to fully support external determination of system parameters. B/P Bios provides a method of achieving these goals, while also possessing the flexibility to operate on a wide range of hardware systems with a much smaller level of systems programming than previously required.
|
||||
|
||||
|
||||
## 1.1 About This Manual
|
||||
|
||||
Documentation on B/P Bios consists of this manual plus the latest addendum on the distribution disk in the file README.2ND. This manual is divided into the following sections:
|
||||
|
||||
* The Features of B/P Bios summarizes the significant features of B/P Bios in general, highlighting advantages and the few limitations in the system.
|
||||
|
||||
* Tailoring B/P Bios contains details on altering the many options to generate a customized `.REL` file tailored to your system.
|
||||
|
||||
* Installing a B/P Bios details the installation of B/P Bios in both Unbanked and Banked configurations in a "how to" fashion.
|
||||
|
||||
* Programming for B/P Bios describes the interfaces, data structures and recommended programming practices to insure the maximum benefit and performance from systems with B/P Bios.
|
||||
|
||||
* The B/P Bios Utilities describes the purpose, operation, and customization of all supplied B/P Bios utilities and support routines.
|
||||
|
||||
* Appendices which summarize various technical information.
|
||||
|
||||
* A glossary defining many technical terms used in this Manual.
|
||||
|
||||
* An index of key words and phrases used in this Manual.
|
||||
|
||||
For those not interested in the technical details, or who want to bring the system up with a pre-configured version as quickly as possible, Section 4, Installing a B/P Bios, will lead you through the installation steps needed to perform the final tailoring to your specific computer. Other chapters cover details of the individual software modules comprising the B/P Bios, and specifics on the utilities provided to ease you use of this product.
|
||||
|
||||
|
||||
## 1.2 Notational Conventions
|
||||
|
||||
Various shorthand terms and notations are used throughout this manual. Terms are listed in the Glossary at the end of this manual.
|
||||
|
||||
Though the symbols seem cryptic at first, they are a consistent way of briefly summarizing program syntax. Once you learn to read them you can tell at a glance how to enter even the most complicated commands.
|
||||
|
||||
Several special symbols are used in program syntax descriptions. By convention, square brackets (\[\]) indicate optional command line items. You may or may not include items shown between brackets in your command, but if you do not, programs usually substitute a default value of their own. If items between brackets are used in a command, all other items between the brackets must also be used, unless these items are themselves bracketed.
|
||||
|
||||
All of the support utilities developed to support the B/P Bios system contain built-in help screens which use the above conventions to display helpful syntax summaries. Help is always invoked by following the command with two slashes (`//`). So for example,
|
||||
|
||||
`ZXD //`
|
||||
|
||||
invokes help for ZXD, the ZSDOS extended directory program. Interactive ZSDOS programs such as BPCNFG2 also contain more detailed help messages which appear as a session progresses.
|
||||
|
||||
Many utilities may be invoked from the command line with options which command the programs to behave in slightly different ways. By convention, options are given after other command parameters. For example, the `P` option in the command
|
||||
|
||||
`ZXD *.* P`
|
||||
|
||||
causes the ZXD directory utility to list all files (*.*) and send its output to the printer (P). For convenience, a single slash character (/) can often be used in place of leading parameters to signify that the rest of the command line consists of option characters. Therefore, the command
|
||||
|
||||
`ZXD /P`
|
||||
|
||||
is identical in meaning to the previous example (see 6.23 for more on ZXD).
|
||||
|
||||
|
||||
## 1.3 What is B/P Bios?
|
||||
|
||||
B/P Bios is a set of software subroutines which directly control the chips and other hardware in your computer and present a standard software interface to the Operating System such as our ZSDOS/ZDDOS, Echelon's ZRDOS, or even Digital Research's CP/M 2.2. These routines comply with the CP/M 2.2 standards for a Basic IO System (BIOS) with many extensions; some based on CP/M 3.x (aka CP/M Plus), and others developed to provide necessary capabilities of modern software. When properly coded, the modules comprising a B/P Bios perform with all the standard support utilities, nearly all Z-System utilities, and most application programs without alteration.
|
||||
|
||||
The ability to operate Banked, Non-banked and Boot System versions of the Bios with a single suite of software, across a number of different hardware machines, plus the maximization of Transient Program Area for application programs in banked systems are features which are offered by no other system of which we are aware.
|
||||
|
||||
|
||||
## 1.4 The History of B/P Bios
|
||||
|
||||
Our earlier work developing ZSDOS convinced us that we needed to attack the machine-dependent software in Z80-compatible computers and develop some standard enhancements in order to exercise the full potential of our machines. This premise is even more true today with large Hard Disks (over 100 Megabytes) being very common, needs for large RAM Drives, and an ever shrinking Transient Program Area. Attempts to gain flexibility with normal operating systems were constrained by the 64k addressable memory range in Z80-compatible systems, and forced frequent operating system changes exemplified by NZCOM and NZBLITZ where different operating configurations could be quickly changed to accommodate application program needs.
|
||||
|
||||
In the mid to late 1980's, several efforts had been made to bank portions of CP/M 2.2 "type" systems. XBIOS was a banked Bios for only the HD64180-based MicroMint SB-180 family. While it displayed an excellent and flexible interface and the ability to operate with a variety of peripherals, it had several quirks and noticeably degraded the computer performance. A banked Bios was also produced for the XLM-180 single board S-100 computer, but required special versions of many Z-System utilities, and was not produced in any significant quantity. Other spinoffs, such as the Epson portable, attempted banking of the Bios, but most failed to achieve our comprehensive goals of compatibility with the existing software base, high performance, and portability.
|
||||
|
||||
In 1989, Cam developed the first prototype of B/P Bios in a Non-banked mode on his TeleTek while Hal concentrated on extending ZSDOS and the Command Processor. As of 1997, B/P Bios has been installed on:
|
||||
|
||||
| Computer | Features |
|
||||
| :--- | :--- |
|
||||
| YASBEC | Z180 CPU, FD1772 FDC, DP8490 SCSI, 1MB RAM |
|
||||
| Ampro LB w/MDISK | Z80 CPU, FD1770 FDC, MDISK 1MB RAM |
|
||||
| MicroMint SB-180 | HD64180 CPU, SMS9266 FDC, 256KB RAM |
|
||||
| MicroMint SB180FX | HD64180Z CPU, SMS9266 FDC, 512KB RAM |
|
||||
| Compu/Time S-100 | Z80 CPU, FD1795 FDC, 1 MB RAM |
|
||||
| Teletek | Z80 CPU, NEC765 FDC, 64KB RAM |
|
||||
| D-X Designs P112 | Z182 CPU, SMC FDC37C665 FDC, Flash ROM, 512KB RAM (mods for 5380 SCSI and GIDE) |
|
||||
|
||||
36
Doc/CPM/BPBIOS/BPBIOS_2_Features.md
Normal file
36
Doc/CPM/BPBIOS/BPBIOS_2_Features.md
Normal file
@@ -0,0 +1,36 @@
|
||||
# 2 Features of B/P Bios
|
||||
|
||||
B/P BIOS is designed to be completely compatible with the CP/M 2.2 standards for a Basic IO System, as well as to provide many extensions needed for banked memory which is becoming so prevalent with newer systems and processors. Additionally, strict coding standards used in the various modules forming the BIOS ease interface problems with applications programs and provide a more robust framework for future development. The extensions added to the basic CP/M 2.2 foundation include many elements from Digital Research's CP/M 3 (aka CP/M Plus), but in a more logically consistent manner. Also included in banked versions are provisions for managing up to 8 MB of extended memory for banked applications, RAM Drives and potentially multitasking in future versions. To provide insight into the methodology used, let us now examine some of the features in a generic B/P Bios.
|
||||
|
||||
|
||||
## 2.1 Character IO
|
||||
|
||||
As defined by Digital Research in their CP/M 2.2 standards, character IO consisted of logical devices referred to as TTY, CRT, UC1, CON, etc. B/P Bios extends and generalizes these interfaces using the IOBYTE to define four physical devices called COM1, COM2, PIO and NUL. The first two, COM1 and COM2, are serial ports; PIO is a Parallel port, while NUL is a "bit-bucket" which can be replaced by a customized driver, or used in lieu of an actual device. Digital Research provided only a limited interface capability to the character devices in CP/M 2.2, consisting of a Console (CON), an auxiliary Input and Output (RDR/PUN), and a Printer (LST). The ability to sense Input and Output Status with these devices was extremely limited and was enhanced in CP/M 3. These enhanced capabilities are completely incorporated into B/P Bios with the addition of strict register usage so that only relevant registers may be altered in the respective routines. By manipulating the IOBYTE, any of the four physical devices may be used in the three logical devices of CONsole, AUXiliary, and Printer (LST).
|
||||
|
||||
Also featured in B/P Bios are modifications of CP/M 3 functions to initialize (or re-initialize) all devices and parameters, and return the address of a table which contains names and parameters of the defined character devices. While not totally compatible with CP/M 3 equivalents, these functions are consistent with the spirit and functionality needed with this advanced system. Included in the device table are; flags defining whether the device is capable of Input, Output or Both, Data rates for serial devices (Maximum and Set), Serial data format where applicable, and Handshaking method (CTS/RTS, XON/XOFF or None), as well as Input and Output Data masks for stripping unneeded bits from characters during IO.
|
||||
|
||||
|
||||
## 2.2 Mass Storage IO
|
||||
|
||||
All versions of Digital Research's CP/M BIOSes define only a generic Disk driver with implementations of Floppy, Hard, RAM and Tape drives left to the user or developer. In B/P Bios, we went several steps further to ease many problems. First, we retained all standard CP/M 2.2 functions and parameters, added CP/M 3 features for returning the Disk Parameter Header (DPH) table address, and flushing of the software deblocking code segment, and added a new vector to the BIOS jump table to provide a standard method of directly addressing low-level device functions. Several standard low-level Floppy Disk functions are supported and used by the standard utilities, including a function to return the type of Disk Controller in use which permits a single support utility to adapt to a wide variety of hardware platforms. In a like manner, low-level functions are provided for SCSI/SASI Hard Disk drives, and provisions for RAM Disk drives in the event special hardware is implemented. The methods used to implement these access mechanisms may be logically extended to handle Tape Drives or Network Interfaces.
|
||||
|
||||
|
||||
## 2.3 Clock Support for Time and Date
|
||||
|
||||
Many Hardware vendors have added provisions for Time and Date as non-standard extensions to CP/M 2.2 BIOSes, and more have incorporated such support into CP/M 3 BIOSes. We opted to define the CP/M 3 clock vector as a ZSDOS-standard clock building on our previous Operating System work. This entry point into the Bios completely complies with our ZSDOS standards and can completely replace the separate clock driver when used with ZSDOS. For systems capable of returning tenths-of-seconds, such as the YASBEC and SB-180, the standard has been enhanced to support this capability as well.
|
||||
|
||||
|
||||
## 2.4 Banked Memory Support
|
||||
|
||||
While Digital Research added banked memory support to their CP/M 3, it was in a manner incompatible with Bios interface standards defined for earlier CP/M standards. The method used in B/P Bios is compliant with CP/M 2.2 in direct accessing of Bios functions with only one minor exception when using the Banked ZSDOS2, and contains many of the CP/M 3 extensions added for banked memory support, with some being modified to be consistent with standards adopted for Z-System software. The exception to CP/M 2.2 accesses occurs when the Operating System can access certain buffers in the System Memory Bank. With ZSDOS 2, Allocation Bit Buffers (ALV), Check Buffers (CSV), and the Disk Host Buffer are all contained in the System Bank and not directly accessible from Transient Programs. To compensate for this, we have added a command to ZSDOS 2 to return the free space on disks (the most common reason for accessing these buffers) and tailored several utilities to adapt to banked and non-banked systems.
|
||||
|
||||
In addition to the primitives initiated by Digital Research, we added functions to directly access Words and Bytes in extended banks of memory, Directly accessing software routines contained in alternate memory banks, and properly managing the system when errors occur. These features make B/P Bios much more robust and resilient than other products. These features are implemented by methods transparent to the system utilities so that the same functions are available in both banked and non-banked versions.
|
||||
|
||||
|
||||
## 2.5 Other Features
|
||||
|
||||
B/P Bios contains a standardized identification method which may be used to determine the hardware on which the software is operating. This allows applications to "adapt" to the environment in a manner similar to that used in the rest of the Z-System community. It also minimizes system "crashes" by executing programs which assume certain hardware features which may be detrimental if executed on other systems. The effects of identification of physical system parameters is most readily noticed by virtue of a single suite of support programs performing low-level functions such as formatting and diagnostics which function across widely differing hardware platforms. Portability on this scale can rarely be seen in other computer systems.
|
||||
|
||||
The ZCPR 3.4 Environment with extensions is mandatory in a B/P Bios system. Beginning with the addition of System Segment address and size information for CPR, DOS and BIOS which were added in the ZCPR 3.4 Environment, B/P Bios also adds a Resident User Space which may be used to locate unique routines for custom applications in a manner similar to, but more consistent than NZ-COM. An Environment Version number of 90H identifies the Z3 Environment as being compliant with B/P definitions.
|
||||
|
||||
In Banked systems, application programs may also be placed in alternate memory banks using location and sizing information contained at standard positions within the Bios Header Structure. This feature permits significantly greater functionality without sacrificing precious Transient Program Area. While the scheme employed in the initial distribution is subject to minor adjustments as the banked ZSDOS2 becomes more firmly developed, experimentation and suggestions into this realm are encouraged.
|
||||
232
Doc/CPM/BPBIOS/BPBIOS_3_Tailoring.md
Normal file
232
Doc/CPM/BPBIOS/BPBIOS_3_Tailoring.md
Normal file
@@ -0,0 +1,232 @@
|
||||
# 3 Tailoring a B/P Bios
|
||||
|
||||
To customize a B/P Bios for your use, or adapt it to a new hardware set, you will need an editor and an assembler capable of producing standard Microsoft Relocatable files. Systems using the Hitachi HD64180 or Zilog Z180 must be assembled with either ZMAC or SLR180 which recognize the extended mnemonic set, or with a Z80 assembler and MACRO file which permits assembly of the extended instructions. For Z80 and compatible processors, suitable assemblers include ZMAC and Z80ASM. For any assembler, failure to produce standard Microsoft Relocatable code will preclude the ability of our Standard utilities to properly install B/P Bios systems.
|
||||
|
||||
|
||||
## 3.1 Theory of Operation
|
||||
|
||||
In order to understand the need for, and principles behind B/P Bios, you must understand the way in which CP/M 2.2, as modified by the Z-System, uses the available memory address space of a Z80 microprocessor. For standard versions of CP/M and compatible systems, the only absolute memory addresses are contained in the Base Page which is the range of 0 to 100H. All addresses above this point are variable (within certain limits). User programs are normally run from the Transient Program Area (TPA) which is the remaining space after all Operating System components have been allocated. The following depicts the assigned areas pictorially along with some common elements assigned to each memory area:
|
||||
|
||||
```generic
|
||||
FFFFH /------------------\
|
||||
| Z-System Buffers | ENV, TCAP, IOP, FCP, RCP
|
||||
|------------------|
|
||||
| Bios | Code + ALV, CSV, Sector Buffers
|
||||
|------------------|
|
||||
| Operating System | CP/M 2.2, ZRDOS, ZSDOS1
|
||||
|------------------|
|
||||
| Command Processor| CCP, ZCPR3.x
|
||||
|------------------|
|
||||
| Transient |
|
||||
| |
|
||||
| Program |
|
||||
| |
|
||||
| Area |
|
||||
0100H |------------------|
|
||||
| Base Page | IOBYTE, Jmp WB, Jmp Dos, FCB, Buffer
|
||||
0000H \------------------/
|
||||
```
|
||||
|
||||
As more and more functionality was added to the Z-System Buffers, bigger drives were added using more ALV space, and additional functionality was added to Bios code in recent systems, the available TPA space has become increasingly scarce.
|
||||
|
||||
B/P Bios attacks this problem at the source in a manner which is easily adaptable to different hardware platforms. It uses additional memory for more than the traditional role of simple RAM Disks, it moves much of the added overhead to alternate memory banks. The generic scheme appears pictorially as:
|
||||
|
||||
```generic
|
||||
FFFFH /----------\
|
||||
| |
|
||||
| BNK1 |
|
||||
| |
|
||||
8000H |----------| /----------\ /----------\ /----------\
|
||||
| | | |\ | |\ | |\
|
||||
| BNK0 | | BNK2 | | BNKU | | BNK3 ||\
|
||||
| | | || | || | |||
|
||||
0000H \----------/ \----------/ \----------/ \----------/
|
||||
\- - - - - / \- - - - - / \- - - - - /|
|
||||
| BNKM |
|
||||
\----------/
|
||||
TPA SYSTEM USER RAM DISK
|
||||
```
|
||||
|
||||
As can be seen from the above diagram, multiple banks of memory may be assigned to different functional regions of memory, with each 32k bank (except for the one defined as BNK1) being switched in and out of the lower 32k of the processor's memory map. The bank defined as BNK1 is ALWAYS present and is referred to as the Common Bank. This bank holds the portions of the Operating System (Command Processor, Operating System, BIOS, and Z-System tables) which may be accessed from other areas, and which therefore must always be "visible" in the processor's memory. It also contains the code to control the Bank switching mechanisms within the B/P Bios.
|
||||
|
||||
To illustrate this functional division, the memory map of a basic B/P Bios system is divided as:
|
||||
|
||||
```generic
|
||||
FFFFH /------------------\
|
||||
| Z-System Buffers |
|
||||
|------------------|
|
||||
| User Space |
|
||||
|------------------|
|
||||
| Bios |
|
||||
|------------------|
|
||||
| Operating System |
|
||||
|------------------|
|
||||
| Command Processor| /------------------\ 8000H
|
||||
|------------------| / | Bios Buffers |
|
||||
8000H | Transient | | Banked Bios Part |
|
||||
| | |------------------|
|
||||
| | | Banked Dos Part |
|
||||
| Program | |------------------|
|
||||
| | | Banked CCP Part |
|
||||
| | |------------------|
|
||||
| Area | | CCP Restoral |
|
||||
0100H |------------------| |------------------| 0100H
|
||||
| Base Page | | Base Page Copy |
|
||||
0000H \------------------/ \------------------/ 0000H
|
||||
TPA (BNK0/BNK1) System Bank (BNK2)
|
||||
```
|
||||
|
||||
The B/P Bios banking concept defines a one byte Bank Number permitting up to 8 Megabytes to be directly controlled. Certain assumptions are made in the numbering scheme, the foremost of which is that BNK0 is the lowest physical RAM bank, BNK1 is the next incremental RAM bank, with others follow in incrementing sequential order. A couple of examples may serve to illustrate this process. The YASBEC is offered with a couple of options in the Memory Map. Units with the MEM-1, 2 or 3 decoder PALs assign the first 128k bytes of physical memory to the Boot ROM, so BNK0 is set to 4 (Banks 0-3 are the ROM). The MEM-4 PAL only uses the first 32k (Physical Bank 0) for the ROM which means that BNK0 is assigned to 1, BNK1 to 2 and so on up to the 1 Megabyte maximum where BNKM is 31.
|
||||
|
||||
The Ampro Little Board equipped with MDISK, on the other hand, completely removes the Boot ROM from the memory map leaving a maximum of 1 MB of contiguous RAM space. In this system, BNK0 is set to 0 and BNKM to 31 of a fully equipped 1 MB MDISK board.
|
||||
|
||||
The region beginning after BNK1 is referred to as the System Bank. It begins at the bank number assigned to BNK2 and ends at the bank number immediately before that assigned to the User Bank, BNKU if present, or BNK3 if no User Bank area is defined.
|
||||
|
||||
If present, one or more 32k banks of memory may be defined with the BNKU equate for unique user programs or storage areas. This area begins with the bank number set to the label and ends at the bank number immediately before the BNK3 label. BNK3 defines a high area of physical memory which is most often used for a RAM Disk providing fast temporary workspace in the form of an emulated disk drive.
|
||||
|
||||
B/P Bios contains protection mechanisms in the form of software checks to insure that critical portions of the memory map are enforced. In the case of Non-banked systems, a check is made to insure that the system size is not so great that the Bios may overwrite reserved Z-System areas in high memory (RCP, IOP, etc). If a possible overflow condition is detected, the message
|
||||
|
||||
`++ mem ovfl ++`
|
||||
|
||||
will be issued when the system is started. In Banked Bios systems, this message will be displayed if the top of the system portions in the SYStem Bank exceeds the 32k bank size. For most systems, this space still permits drives of several hundred megabytes to be accommodated.
|
||||
|
||||
Since the Common portions of the operating system components must remain visible to applications, a similar check is made to insure that the lowest address used by the Command Processor is equal to or greater than 8000H. This factor is checked both in both MOVxSYS and BPBUILD with either a warning issued in the case of the former, or validity checks on entry in the case of the latter.
|
||||
|
||||
|
||||
## 3.2 B/P Bios Files
|
||||
|
||||
This BIOS is divided into a number of files, some of which depend highly on the specific hardware used on the computer, and some of which are generic and need not be edited to assemble a working system. Much use is made of conditional assembly to tailor the resulting Bios file to the desired configuration. The Basic file, `BPBIO-xx.Z80`, specifies which files are used to assemble the Bios image under the direction of an included file, `DEF-xx.LIB`. It is this file which selects features and contains the Hardware-dependent mnemonic equates. By maintaining the maximum possible code in common modules which require no alterations, versions of B/P Bios are relatively easy to convert to different machines. The independent modules used in the B/P Bios system are:
|
||||
|
||||
| Filename | Description |
|
||||
| :--- | :--- |
|
||||
| `BOOTRAM.Z80` | (only needed in BOOT ROM applications) |
|
||||
| `BOOTROM.Z80` | (only needed in BOOT ROM applications) |
|
||||
| `BYTEIO.Z80` | Character IO per IOBYTE using IIO-xx routines |
|
||||
| `DEBLOCK.Z80` | Disk Deblocking routines |
|
||||
| `DPB.LIB` | 3.5/5.25" Floppy Format Definitions (if AutoSelect) |
|
||||
| `DPB8.LIB` | 8"/Hi-Density Floppy Format Definitions (if AutoSelect) |
|
||||
| `DPB2.LIB` | Additional Floppy Definitions (optional if AutoSelect) |
|
||||
| `DPBRAM.LIB` | Fixed Floppy Format Definitions (if Not AutoSelect) |
|
||||
| `DPH.LIB` | Disk Parameter Header Table & Floppy definitions |
|
||||
| `FLOPPY.Z80` | Floppy Disk High-Level Control |
|
||||
| `SECTRAN.Z80` | Sector Translate routines |
|
||||
| `SELFLP1.Z80` | Floppy Select routine (if Not auto selecting) |
|
||||
| `SELFLP2.Z80` | Floppy Select routine (if auto selecting) |
|
||||
| `SELRWD.Z80` | Generic Read/Write routines |
|
||||
| `Z3BASE.LIB` | ZCPR 3.x file equate for Environment settings |
|
||||
|
||||
Other files are hardware version dependent to varying extents. These modules requiring customization for different hardware systems are given names which end with a generic "-xx" designator to identify specific versions. Tailoring these modules ranges from simple prompt line customization to complete re-writes. Versions of B/P Bios generated to date are identified as:
|
||||
|
||||
| ID | Computer system |
|
||||
| :---: | :--- |
|
||||
| `-18` | MicroMint SB-180 | (64180 CPU, 9266 FDC, 5380 SCSI) |
|
||||
| `-YS` | YASBEC | (Z180 CPU, 1772 FDC, DP8490 SCSI) |
|
||||
| `-AM` | Ampro Little Board | (Z80 CPU, 1770 FDC, 1MB MDISK) |
|
||||
| `-CT` | Compu/Time S-100 board set | (Z80 CPU, 1795 FDC, 1MB Memory) |
|
||||
| `-TT` | Teletek | (Z80 CPU, 765 FDC) |
|
||||
|
||||
Files associated with specific hardware versions or require tailoring are:
|
||||
|
||||
| Filename | Description |
|
||||
| :--- | :--- |
|
||||
| `BPBIO-xx.Z80` | Basic file, tailored for included file names |
|
||||
| `CBOOT-xx.Z80` | Cold Boot routines, Sign-on prompts |
|
||||
| `DEF-xx.LIB` | Equates for option settings, mode, speed, etc. |
|
||||
| `DPBHD-xx.LIB` | Hard Drive Partition Definitions (optional) |
|
||||
| `DPBM-xx.LIB` | Ram Drive Definition (optional) |
|
||||
| `DPHHD-xx.LIB` | Hard Drive DPH definitions (optional) |
|
||||
| `DPHM-xx.LIB` | Ram Drive DPH Definition (optional) |
|
||||
| `FDC-xx.Z80` | Floppy Disk Low-Level interface/driver routines |
|
||||
| `HARD-xx.Z80` | Hard Drive Low-Level interface/driver routines (optional) |
|
||||
| `IBMV-xx.Z80` | Banking Support Routines (if banked) |
|
||||
| `ICFG-xx.Z80` | Configuration file for speed, Physical Disks, etc. |
|
||||
| `IIO-xx.Z80` | Character IO definitions and routines |
|
||||
| `RAMD-xx.Z80` | Ram Drive interface/driver routines (optional) |
|
||||
| `TIM-xx.Z80` | Counter/Timer routines and ZSDOS Clock Driver |
|
||||
| `WBOOT-xx.Z80` | Warm Boot and re-initialization routines |
|
||||
|
||||
|
||||
## 3.3 B/P Bios Options
|
||||
|
||||
The most logical starting point in beginning a configuration is to edit the `DEF-xx.LIB` file to select your desired options. This file is the basic guide to choosing the options for your system, and some careful choices here will minimize the Bios size and maximize your functionality. Some of the more important options and a brief description of them are:
|
||||
|
||||
**MOVCPM** - Integrate into MOVCPM "type" loader? If the system is to be integrated into a MOVCPM system, the Environment descriptor contained in the CBOOT routine is always moved into position as part of the Cold Start process. If set to NO, a check will be made to see if an Environment Descriptor is already loaded, and the Bios copy will not be loaded if one is present.
|
||||
|
||||
NOTE: When assembling a Bios for Boot Track Installation (MOVCPM set to YES), many options are deleted to conserve space and the Bios Version Number is forced to 1.1.
|
||||
|
||||
**BANKED** - Is this a banked BIOS? If set to YES, the Bank control module, IBMV, is included in the assembly, and much of the code is relocated to the system bank. Note that a Banked system CANNOT be placed on the System Tracks, or integrated into a MOVCPM image.
|
||||
|
||||
**IBMOVS** - Are Direct Inter-Bank Moves possible? If set to YES, direct transfer of data between banks is possible such as with the Zilog Z180/Hitachi 64180. If NO, a 256-byte transfer buffer is included in high Common Memory and Interbank moves require transfer of bytes through this buffer.
|
||||
|
||||
**ZSDOS2** - Assemble this for a Banked ZSDOS2 system? If YES, the ALV and CSV buffers will be placed in the System bank invisible to normal programs. This has the side effect that many CP/M programs which perform sizing of files (Directory Listers, DATSWEEP, MEX, etc) which do not know about this function will report erroneous sizes. The advantage is that no sacrifice in TPA is required for large Hard Disks. Set this to NO if you want strict CP/M 2.2 compatibility.
|
||||
|
||||
**FASTWB** - Restore the Command Processor from the System Bank RAM? If set to YES, Warm Boots will restore the Command Processor from a reserved area in the System RAM bank rather than from the boot tracks. For the maximum benefit of B/P Bios, always attempt to set this to YES. In systems without extended memory, it MUST be set to NO.
|
||||
|
||||
**MHZ** - Set to Processor Speed in closest even Megahertz (e.g. for a 9.216 MHz clock rate, set to 9). The value entered here is used in many systems to compute Timing values and/or serial data rate parameters.
|
||||
|
||||
**CALCSK** - Calculate Diskette Skew Table? If NO, a Skew table is used for each floppy format included in the image. Calculating Skew is generally more efficient from a size perspective, although slightly slower by factors which are so small as to be practically unmeasurable.
|
||||
|
||||
**HAVIOP** - Include IOP code into Jump table? If the IOPINIT routine satisfies your IOP initialization requirements, you may turn this off by setting to NO and save a little space. This typically will be turned off when generating a system for MOVCPM integration to conserve space.
|
||||
|
||||
**INROM** - Is the Alternate Bank in ROM? Set to NO for Normal Disk-based systems. Please contact the authors if you need additional information concerning ROM-based system components.
|
||||
|
||||
**BIOERM** - Print BIOS error messages? Set this to YES if you desire direct BIOS printing of Floppy Disk Error Messages. If you are building a BIOS for placement on Boot Tracks, however, you will probably not have room and must turn this Off. Set to NO to simply return the normal Success/Fail error flag with no Message printout.
|
||||
|
||||
**FLOPY8** - Include 8"/Hi-Density Floppy Formats? Some systems (SB-180, Compu/Time) can handle both 5.25" and 8" disks. If your hardware supports the capability and you want use 8" disks as well as the normal 3.5 and 5.25" diskettes, setting this to YES will add formats contained in `DPB8.LIB` and control logic to the assembly. Future systems may take advantage of the "High-Density" 3.5 and 5.25" Floppy Disks which use higher data rates. Their definitions will be controlled by this flag as well.
|
||||
|
||||
NOTE: If AUTOSL is set to NO, this option will probably cause the BIOS to be larger than necessary since these additional formats may not be accessible.
|
||||
|
||||
**MORDPB** - Use more Floppy DPB's (in addition to normal 4-5.25" and optional 8")? If YES, the file `DPB2.LIB` is included. Many of the formats are Dummies and may be filled with any non-conflicting formats you desire.
|
||||
|
||||
NOTE: If AUTOSL if set to NO, this option will probably cause the BIOS to be larger than necessary since these additional formats may not be accessible.
|
||||
|
||||
**MORDEV** - Include Additional Character Device Drivers? Is set to YES, user-defined drivers are added to the Character IO table, and associated driver code is assembled. Systems featuring expansion board such as the SB-180 and YASBEC may now take advantage of additional serial and parallel interfaces within the basic Bios. Set to NO to limit code to the basic 4 drivers.
|
||||
|
||||
NOTE: When assembling a Bios for Boot Track Installation (MOVCPM set to YES), MORDEV is overridden to conserve space, and the Bios Version Number is forced to 1.1 in the distribution files.
|
||||
|
||||
**BUFCON** - Use type ahead buffer for the Console? If set to YES, code is added to create and manage a type-ahead buffer for the driver assembled as the console. This device will be controlled by either interrupts (in systems such as the YASBEC and SB-180) or background polling (in Ampro and Compu/Time). This means that characters typed while the computer is doing something else will not be lost, but will be held until requested.
|
||||
|
||||
**BUFAUX** - Use type ahead buffer on Auxiliary Port? As with BUFCON above, setting to YES will add code to create and manage a type ahead buffer for the auxiliary device. Since the AUX port typically is used for Modem connections, buffering the input will minimize the loss of characters from the remote end.
|
||||
|
||||
**AUTOSL** - Auto-select floppy formats? If set to YES, selection of Floppy disks will use an algorithm in `SELFLP2.Z80` to identify the format of the disk from the DPB files included (`DPB.LIB`, optional `DPB8.LIB`, and optional `DPB2.LIB`) and log the disk if a match is found. There must be NO conflicting definitions included in the various files for this to function properly. See the notes in the various files to clarify the restrictions. If set to NO, the single file `DPBRAM.LIB` is included which may be tailored to contain only the fixed format or formats desired per disk drive. This results in the smallest code requirement, but least flexibility.
|
||||
|
||||
**RAMDSK** - Include code for a RAM-Disk? If set to YES, any memory above the System or User bank may be used for a RAM Drive (default is drive M:) by including the file `RAMD-xx.Z80`. Parameters to determine the size and configuration are also included in the files `DPHM-xx.LIB` and `DPBM-xx.LIB`. In systems without extended memory, or to conserve space such as when building a system for the boot tracks, this may be disabled by setting to NO.
|
||||
|
||||
**HARDDSK** - Include SCSI Hard Disk Driver? Set to YES if you wish to include the ability to access Hard Disk Drives. In a floppy-only system, a NO entry will minimize BIOS code.
|
||||
|
||||
**HDINTS** - (System Dependent) In some systems such as the YASBEC, Interrupt-driven Hard Disk Controllers using DMA transfer capabilities may be used. If you wish to use this type of driver specified in the file `HARDI-xx.Z80` instead of the normal polled routines included in `HARD-xx.Z80`, set this option to TRUE. In most cases, this driver will require more Transient Program Area since the Interrupt Handling routine must be in Common Memory.
|
||||
|
||||
**CLOCK** - Include ZSDOS Clock Driver Code? If set to YES, the vector at BIOS+4EH will contain a ZSDOS-compatible clock driver with the physical code contained in the `TIM-xx.Z80` module. If set to NO, calls to BIOS+4EH return an error code.
|
||||
|
||||
**TICTOC** - (System Dependent) Use pseudo heartbeat counter? This feature is used in systems such as the Ampro Little Board and Compu/Time SBC880 which do not have an Interrupt scheme to control a Real Time Clock. Instead, a series of traps are included in the code (Character IO Status polls, Floppy Disk Status polls) to check for overflow of a 1-Second Counter. It is less desirable than an Interrupt based system, but suffices when no other method is available. Set to NO if not needed.
|
||||
|
||||
**QSIZE** - Size in bytes of type ahead buffers controlled by BUFCON and BUFAUX.
|
||||
|
||||
**REFRSH** - Activate Dynamic Refresh features of Z180/HD64180 processors? In some computers using these processors such as the YASBEC, refresh is not needed and merely slows down processing. Set to NO if you do not need this feature. If your processor uses dynamic memory, or needs the signal for other purposes (e.g. The SB180 uses Refresh for Floppy Disk DMA), Set this to YES.
|
||||
|
||||
**Z3** - Include ZCPR init code? Since a Z3 Environment is mandatory in a B/P Bios (which now "owns" the Environment), this option has little effect.
|
||||
|
||||
For assembly of a Banked version of B/P Bios, the identification of various banks of memory must be made so that the various system components "know" where things are located. Refer to Section 3.1 above for a description of these areas. The BNK0 value should be the first bank of RAM in the System unless other decoding is done. The following equates must be set:
|
||||
|
||||
| Equate | Description |
|
||||
| :--- | :--- |
|
||||
| BNK0 | First 32k TPA Bank (switched in/out) |
|
||||
| BNK1 | Second 32k TPA Bank (Common Bank) |
|
||||
| BNK2 | Beginning of System Bank (BIOS, DOS, CPR) area |
|
||||
| BNKU | Beginning of Bank sequence for User Applications |
|
||||
| BNK3 | Beginning of Extra Banks (first bank to use for RAM Disk) |
|
||||
| BNKM | Maximum Bank Number assigned |
|
||||
|
||||
|
||||
## 3.4 Configuration Considerations
|
||||
|
||||
When assembling a version of B/P Bios for integration into an IMG file, size of the resulting image is not much of a concern, so you need not worry about minor issues of size. For integration into a system for loading onto diskette boot tracks, however, the limitation is very real in order to insure that the CPR/DOS/BIOS and Boot Sector(s) can fit on the reserved system tracks. Typically, a limit of slightly under 4.5k exists for the Bios component. When the MOVCPM flag is set to YES for this type of assembly, warnings will be issued when the image exceeds 4352 bytes (the maximum for systems with 2 boot records), and 4480 bytes (the maximum for systems with a single boot record). Achieving these limits often requires disabling many of the features.
|
||||
|
||||
The first thing you should do before assembling the BIOS is to back up the entire disk, then copy only the necessary files onto a work disk for any editing. After setting the options as desired, edit the hardware definitions in `ICFG-xx.Z80` to reflect the physical characteristics of your floppy and hard drives, as well as any other pertinent items. Then edit the logical characteristics for your Hard and Ram Drives (if any) in `DPBHD-xx.LIB` and `DPBM-xx.LIB`. If you do not desire any of the standard floppy formats or want to change them, edit `DPB.LIB` and/or `DPB2.LIB` (if using auto selection) or `DPBRAM.LIB` if you are using fixed floppy formats. Finally edit the DPH files to place the logical drives where desired in the range A..P.
|
||||
|
||||
Decide whether you want to generate a system using the Image file construct developed in support of B/P Bios (BPBUILD/LDSYS), or for integration on a floppy disk's boot tracks. If the latter, you probably will not be able to have all options turned on. For example, with the MicroMint SB-180, the following options must be turned Off: BANKED, ZSDOS2, BIOERM, FLOPY8, MORDPB, BUFAUX and usually either CLOCK or RAMDSK. As an aid to space reduction, conditional assembly based on the MOVCPM flag automatically inhibits all but double-sided Floppy formats from `DPB.LIB`. If configuring for Floppy Boot tracks (MOVCPM flag set to TRUE), a warning will be printed during assembly if the size exceeds that available for a One or Two-sector boot record. Using the BPBUILD/LDSYS method, you may vary nearly all system parameters, even making different systems for later dynamic loading.
|
||||
|
||||
If you are using a version of the B/P Bios already set for your type of computer, you are now ready to assemble, build a system and execute it. The only remaining task would be an optional tailoring of the sign on banner in the file `CBOOT-xx.Z80` and reassembly to a `.REL` file.
|
||||
|
||||
For those converting a standard version of the B/P Bios to a new hardware system, we recommend that you begin with a Floppy-only system in Non-Banked mode then expand from there. The easiest way to test out new versions is to use the System Image (IMG file) mode, then advance to boot track installations if that is desired. Enhancements that can be added after testing previous versions may be to add Hard Drives, RAM Drive, and finally Banking.
|
||||
|
||||
200
Doc/CPM/BPBIOS/BPBIOS_4_Installation.md
Normal file
200
Doc/CPM/BPBIOS/BPBIOS_4_Installation.md
Normal file
@@ -0,0 +1,200 @@
|
||||
# 4 Installing a B/P Bios
|
||||
|
||||
The Distribution diskette(s) on which B/P Bios is furnished are configured for booting from the vanilla hardware for the version ordered. A 9600 bps serial terminal is standard, and will allow you to immediately bring up a minimal Non-Banked Floppy Disk system. Due to the variety of different system configurations and size restrictions in some versions, only the Floppy Disk Mass Storage capability can be assured on the initial boot disk. Where space remained on the boot tracks, limited Hard Drive support is also provided, and in some configurations, even RAM Drive support exists.
|
||||
|
||||
After booting from either an established system, or the boot tracks of the distribution disk, format one or more fresh diskettes and copy the distribution diskette(s) contents to the backup diskette(s). Copy the boot tracks from the master to the copies using BPSYSGEN (see 6.6). Remove the master diskette(s) for safekeeping and work only with the copies you just made.
|
||||
|
||||
Using the backup diskette with the B/P utilities on it, execute BPCNFG in the Boot Track configuration mode (see 6.2), adjusting all the options to your specific operating environment. When you have completed tailoring the system, it is ready for booting by placing the diskette in drive A: and resetting the system.
|
||||
|
||||
The sample `STARTUP.COM` file on the distribution disk will automatically execute a sequence of instructions when the system is booted. It contains various instructions which further tailor the system and load portions of the operating system which are too big to fit on the boot tracks. The default instruction sequence is:
|
||||
|
||||
| Command | Explanation |
|
||||
| :--- | :--- |
|
||||
| `LDDS` | Load the DateStamper style File Stamp routine and clock |
|
||||
| `LDR SYS.RCP,SYS.FCP,SYS.NDR` | Load ZCPR 3 Environment segments for Resident Command Processor, Flow Control Pkg and Named Dirs |
|
||||
| `IOPINIT` | Initialize the IO Processor Pkg |
|
||||
| `TD S` | Prompt for Date and Time, Set Clk / Alternatives are to use `TDD` (6.21) or `SETCLOK` (6.18) |
|
||||
| `IF ~EX MYTERM.Z3T` | If the file `MYTERM.Z3T` does Not exist... |
|
||||
| `TCSELECT MYTERM.Z3T` | ..select which terminal you have creating a `MYTERM.Z3T` file |
|
||||
| `FI` | ...end of the `IF` |
|
||||
| `LDR MYTERM.Z3T` | Load the Terminal Definition data |
|
||||
|
||||
If you wish to alter any of these initial instructions to, for example, initialize the RAM drive using INIRAMD, add File Time Stamp capabilities to it with INITDIR or PUTDS and copy some files there with COPY, these may be added with ALIAS, VALIAS, SALIAS or other compatible files available from the ZSYSTEM or ZCPR33 areas on Z-Nodes.
|
||||
|
||||
After the initial system is up and running from the Default Boot Track system, you may expand the operation by generating systems for different purposes in order to gain the most advantage from your system. Many types of installation are possible, the simplest of which is a Non-Banked system using only 64k of the systems memory, all of which is in primary memory. Such a system uses a normal Command Processor such as the ZCPR3.x family, and a Non-Banked Operating System such as our ZSDOS Version 1. Non-Banked systems may be installed on a Disk's Boot Tracks, or created as an Image File for dynamic loading using the LDSYS Utility (see 6.15).
|
||||
|
||||
Banked systems MUST be created with the BPBUILD Utility (see 6.1) and loaded with LDSYS (see 6.15). The techniques to manage different memory banks to form a complete Operating Environment are rather intricate and are best handled by our utilities. Many Image files may be created and loaded as needed to tailor your system for optimum performance. The following sections describe these various types of installations in detail.
|
||||
|
||||
|
||||
## 4.1 Boot Track Installation
|
||||
|
||||
For most of the existing CP/M compatible computers to begin executing a Disk Operating System, a program must be placed on a specified area of a Floppy or Hard Disk Drive. Normally, the first two or three tracks on the disk are reserved for this purpose and are referred to as the "Boot Tracks". Since the space so defined is generally restricted, neither a complete B/P Bios nor a Banked installation is possible. Instead, a scaled-down system roughly equivalent to those currently in use is used to start the computer and serve as the Operating System, with larger systems loaded later as needed.
|
||||
|
||||
If you are using a pre-configured version of B/P Bios for your hardware, you may simply continue to use the Boot Track system from the distribution disk(s) by copying the system as described in Section 4 above using BPSYSGEN (see 6.6). If you elect to alter or otherwise customize the Boot Track system, you must assemble the B/P Bios source setting certain of the equates in the `DEF-xx.LIB` file to insure a correct type of system. To assemble a Boot Track system, the most important equates are:
|
||||
|
||||
| Equate | |
|
||||
| :---: | :--- |
|
||||
| `MOVCPM` | Set to `YES` |
|
||||
| `BANKED` | Set to `NO` |
|
||||
| `ZSDOS2` | Set to `NO` |
|
||||
|
||||
One element of Banked Systems is available in a Boot Track installation if additional memory is available, and your B/P Bios routines support such a feature. This feature reloads the Command Processor from Banked memory instead of from the Boot Tracks of a disk, and generally produces less code (taking less space on the Boot Tracks) and executes faster. It is set with:
|
||||
|
||||
| Equate | |
|
||||
| :---: | :--- |
|
||||
| `FASTWB` | Set to `YES` if desired, `NO` if Warm Boot from disk |
|
||||
|
||||
Some of the features that generally need to be disabled to scale a smaller system are set as:
|
||||
|
||||
| Equate | |
|
||||
| :---: | :--- |
|
||||
| `MORDPB` | Set to `NO` |
|
||||
| `DPB8` | Set to `NO` |
|
||||
| `MORDEV` | Set to `NO` |
|
||||
|
||||
When at least these equates and any others you desire to change (see section 4) have been made to the component files of the system, assemble your `BPBIO-xx` file to a Microsoft standard `.REL` file. This output file may be used to overlay the Bios portion of the `MOVxSYS.COM` system generation utility (see 6.16) furnished with your distribution disk, or an equivalent program provided with your computer. MOVxSYS or its equivalent (MOVCPM, MOVZSYS, etc) is a special program customized for your particular hardware containing all the Operating System components which will be placed on the Boot Tracks, along with a routine to alter the internal addresses to correspond to a specified memory size.
|
||||
|
||||
To Add the new Bios you just assembled, execute INSTAL12 (see procedures in 6.13) specifying your computer's MOVxSYS or equivalent program and follow the prompts to overlay the new Bios. Once INSTAL12 has saved a relocatable or absolute file, you are ready to create a boot disk containing the modified system.
|
||||
|
||||
If you used the command INSTAL12 to install system segments on MOVxSYS or equivalent program, you must first create an Absolute System Model file. Since the functional portion of your new program is identical to the original MOVxSYS or equivalent, use the method explained in your original documentation to generate a new system. With MOVxSYS, the command is:
|
||||
|
||||
| Command | |
|
||||
| :---: | :--- |
|
||||
| `MOVxSYS nn *` | replace MOVxSYS with your version |
|
||||
|
||||
Where `nn` is the size of the system (typically 51 for a moderate boot system). The asterisk tells the program to retain the image in memory and not write it to a disk file. You may now use BPSYSGEN to write the new image to the system tracks of your boot diskette. Do this by executing BPSYSGEN with no arguments and issue a single Carriage Return when asked for the source of the Image.
|
||||
|
||||
If you used the command `INSTAL12 /A` to install replacement system segments over a System Image file, or used a utility which wrote the new image to a disk file, use BPSYSGEN to write the image file to the system tracks of your boot disk. The proper command is
|
||||
|
||||
`BPSYSGEN filename`
|
||||
|
||||
where filename is the name of the disk file you just created by executing MOVxSYS or equivalent with output to a disk file, or with INSTAL12 on an existing image file.
|
||||
|
||||
If the system is written to a Hard Disk, and your system supports booting from a Hard Disk such as the YASBEC, you normally must alter the default Boot Sector from the default Floppy Disk Boot Sector contained in MOVxSYS or equivalent. This alteration is accomplished by HDBOOT (see 6.9) which must be customized to the specific Hardware System used.
|
||||
|
||||
After the above actions have been completed as appropriate, tailor the Boot Track system to reflect the desired starting configurations with BPCNFG (see 6.2). Such items as the desired Startup file name, Bank Numbers (critical if FASTWB is used), and drive types and assignments are routinely tailored at this point. When the you have finished this step, test your new system by resetting the system, or cycling the power and you should be up and running!
|
||||
|
||||
|
||||
## 4.2 Non-Banked Image Installation
|
||||
|
||||
A Non-Banked system may be installed as an Image File as opposed to the basic Boot Track installation covered in 4.1 above. To create an Image File, you must have `.REL` or `.ZRL` versions of a Command Processor (ZCPR3.x or equivalent recommended), an Operating (`ZSDOS.ZRL` recommended), and a REL version of B/P Bios for your system assembled with the MOVCPM equate in `DEF-xx.LIB` set to NO. Other equates in this file may be set as described above for the Boot Track system. Since Image Files are not as constrained in size as is installation for Boot Tracks, more features may generally be activated such as Error Messages, RAM Drive, additional Hard Drive partitions, and complete Floppy Format suites. The main precaution here is that large Hard Drives will rapidly cause significant loss of Transient Program Area since all Drive parameters must be in protected high memory above the Bios.
|
||||
|
||||
After the Bios has been assembled, an Image file must be produced. This is accomplished with the BPBUILD Utility (see 6.1). Set the File names in Menu 1 to reflect only Non-Banked files (or minimally banked Bios if FASTWB is set to YES), and let BPBUILD do the work. Since the standard Non-Banked System segments are normally set to the "standard" CP/M 2.2 sizes, you may answer the "autosize" query with a Y to obtain the maximum Transient Program Area in the resulting system. When BPBUILD completes its work, a file, normally with the default type of `.IMG`, will have been placed in the currently logged Drive/User area and you are ready to perform the next step in preparation of the Non-Banked Image.
|
||||
|
||||
As with the Boot Track installation covered above, several system items must be tailored before the Image may be safely loaded and executed. This is done by calling BPCNFG with the Image file name as an argument, or specify Image configuration from the interactive menu (see 6.2). Set all items as you desire them in the operating system, particularly the Bank Numbers (if FASTWB is active), and the Disk Drive characteristics and assignments. When this has been satisfactorily completed, you are ready to load and execute the newly-created system.
|
||||
|
||||
Installing an Image File (default file type of `.IMG`) is extremely easy. Only the utility `LDSYS.COM` (see 6.15) is needed. If the file type has not been changed from the default `.IMG`, only the basic name of the Image File need be passed to LDSYS when executed as:
|
||||
|
||||
| Command | |
|
||||
| :---: | :--- |
|
||||
| `LDSYS IMGFILE` | where IMGFILE.IMG is your Image file name |
|
||||
|
||||
The operating parameters of the currently-executing system are first examined for suitability of loading the Image File. If it is possible to proceed, the Image File is loaded, placed in the proper memory locations, and commanded to begin execution by calling the B/P Bios Cold Boot Vector. The Cold Boot (Bios Function 0) performs final installation, displays any desired opening prompt and transfers control to the Command Processor with any specified Startup file for use by a ZCPR3.x Command Processor Replacement.
|
||||
|
||||
Since a non-banked Image File will probably closely resemble that contained on the Boot Tracks, the same STARTUP file may generally be used to complete the initial tailoring sequence. If a different file is desired, the Image File may be altered to specify a different file using BPCNFG.
|
||||
|
||||
|
||||
## 4.3 Banked Bios, Non-banked System Installation
|
||||
|
||||
With the B/P Bios system, an Image system may be created and loaded which places portions of the Bios Only in the System bank, retaining a non-banked Operating System and therefore maximum compatibility with existing applications software. A few thousand bytes can normally be reclaimed for Transient Programs in this manner, although large and/or increasing numbers of logical drives will still reduce TPA space because of the need to store Allocation Vector information in Common Memory.
|
||||
|
||||
To prepare such a system, simply edit the needed Bios files if necessary with particular emphasis on the `DEF-xx.LIB` file where the following equates must be set as:
|
||||
|
||||
| Equate | |
|
||||
| :---: | :--- |
|
||||
| `MOVCPM` | Set to `NO` |
|
||||
| `BANKED` | Set to `YES` |
|
||||
| `ZSDOS2` | Set to `NO` |
|
||||
|
||||
Since banked memory MUST be available for this type of installation, you will probably want the Fast Warm Boot feature available to maximize system performance. To activate this option, set the following equate as:
|
||||
|
||||
| Equate | |
|
||||
| :---: | :--- |
|
||||
| `FASTWB` | Set to `YES` |
|
||||
|
||||
When the editing is complete, assemble the Bios to a Microoft `.REL` file with an appropriate assembler such as ZMAC and build an Image system with BPBUILD (see 6.1) changing the Bios file name in menu 1 to the name of the newly created Bios file. Next, configure the default conditions if necessary with BPCNFG (see 6.2) and you are ready to activate the new system in the same manner as all Image files by calling LDSYS with the Image file argument as:
|
||||
|
||||
| Command | |
|
||||
| :---: | :--- |
|
||||
| `LDSYS BBSYS` | where BBSYS.IMG is your Image File Name |
|
||||
|
||||
As with the completely Non-Banked system described above in Section 4.2, no new requirements are established for a Startup file over that used for the initial Boot System, since both the Command Processor and Disk Operating System are unbanked, and no data areas needed by application programs are placed in the System Bank. As with all Image Files, additional features such as full Bios Error Messages, more extensive Floppy Disk Formats and RAM drive may generally be included in the System definition prior to assembly since the size constraints of Boot Track systems do not apply.
|
||||
|
||||
|
||||
## 4.4 Fully Banked Image Installation
|
||||
|
||||
To create a system taking maximum advantage of banked memory, a special banked Operating System and Command Processor are needed. These have been furnished in initial form with this package as `ZSDOS20.ZRL` and `Z40.ZRL` respectively. They use the Banking features of B/P Bios and locate the maximum practicable amount of executable code and data in the System Bank. Of significant importance to maximizing the Transient Program Area is that the Drive Allocation Bit maps are placed in the System Bank meaning that adding large hard drives, or multiple drives produce only minimal expansion to the resident portion of the Bios.
|
||||
|
||||
NOTE: The latest versions are `ZS203.ZRL`, `ZS227G.ZRL`, and `Z41.ZRL` as included in the public release of B/P Bios. See also sections 7 and 8.
|
||||
|
||||
A Fully banked Bios is created by editing the B/P Bios files as needed to customize the system to your desires. Insure that the following `DEF-xx.LIB` equates are set as:
|
||||
|
||||
| Equate | |
|
||||
| :---: | :--- |
|
||||
| `MOVCPM` | Set to `NO` |
|
||||
| `BANKED` | Set to `YES` |
|
||||
| `ZSDOS2` | Set to `YES` |
|
||||
|
||||
Assemble the resultant B/P Bios to a Microsoft `.REL` file, Build an Image file with BPBUILD (see 6.1) and configure the produced Image file with BPCNFG (see 6.2). When you are confident that all default settings have been made, activate the file by entering:
|
||||
|
||||
| Command | |
|
||||
| :---: | :--- |
|
||||
| `LDSYS FBANKSYS` | where FBANKSYS.IMG is your Image File Name |
|
||||
|
||||
Several differences may exist in the Startup file used for a Fully banked system. Generally the changes amount to deleting items such as a File Stamp module for the Non-banked ZSDOS1 which is not necessary with the fully-banked ZSDOS 2 and Z40. Only the type of clock need be specified for ZSDOS2. Furthermore, since the Z40 Command Processor Replacement contains most commonly-used commands gathered from a number of Resident Command Processor (RCP) packages, there is normally no need to load an RCP. A simple Startup file found adequate during development of the fully-banked B/P system is:
|
||||
|
||||
| Command | Explanation |
|
||||
| :--- | :--- |
|
||||
| `ZSCFG2 CB` | Set ZSDOS 2 clock to Bios+4EH |
|
||||
| `LDR SYS.FCP,SYS.NDR` | Load ZCPR 3 Environment segments for Flow Control and Named Dirs |
|
||||
| `IOPINIT` | Initialize the IO Processor Pkg |
|
||||
| `TD S` | Prompt for Date and Time, Set Clk / Alternatives are to use `TDD` (6.21) or `SETCLOK` (6.18) |
|
||||
| `IF ~EX MYTERM.Z3T` | If the file `MYTERM.Z3T` does Not exist... |
|
||||
| `TCSELECT MYTERM.Z3T` | ..select which terminal you have creating a `MYTERM.Z3T` file |
|
||||
| `FI` | ...end if the `IF` |
|
||||
| `LDR MYTERM.Z3T` | Load the Terminal Definition data |
|
||||
|
||||
Since the requirements for a fully-banked system differ significantly from a non-banked one, we recommend that you use a different name for the Startup file. For example, `STARTUP.COM` is the default name used with Boot Track systems for initial operation, and with Non-banked Image Files, while STARTB may be a suitable name for the script to be executed upon loading a fully-banked system. The name of the desired Startup file may be easily altered in either Boot Track or Image systems from Option 1 in BPCNFG (see 6.2).
|
||||
|
||||
An option available to start from a large Image File is to configure a Startup file for execution by the Boot Track system containing a single command. The command would simply invoke LDSYS with the desired Banked Image File as an argument such as:
|
||||
|
||||
| Command | |
|
||||
| :---: | :--- |
|
||||
| `LDSYS BANKSYS` | where BANKSYS.IMG is your Image file |
|
||||
|
||||
In this case, none of the normal initialization sequences cited above would be executed by the Boot Track system, and only those contained in the Startup for `BANKSYS.IMG` would occur. Other options abound and are left to the community to invent new combinations and sequences.
|
||||
|
||||
|
||||
## 4.5 In Case of Problems...
|
||||
|
||||
While We attempted to outline procedures for the majority of installations we considered feasible, there may be occasions where you inadvertently find yourself in a position where you seem to have lost the ability to get your system up and running.
|
||||
|
||||
**PROBLEM:** When loading an `.IMG` file with LDSYS, the screen displays the LDSYS banner, system addresses, and halts with the last screen displaying: "...loading banked system".
|
||||
|
||||
_SOLUTION:_ Something is not set correctly in the Bios, since all lines after the last one displayed are printed from the newly-loaded Bios. One of the most common causes for this problem is incorrect bank number settings. Use the hidden selection in Menu 1 of BPCNFG (see 6.2) to verify that the correct bank numbers have been set for TPA and SYStem banks. Another common cause of this problem is incorrect settings for the Console port, or a setting in the IOBYTE which directs Console data to a device other than the one intended. Use Menu 2 BPCNFG to properly set the IOBYTE and the console parameters.
|
||||
|
||||
**PROBLEM:** You boot from or load a B/P Bios system from a Hard Drive, and immediately after starting, the system attempts to log onto Floppy Drive 0.
|
||||
|
||||
_SOLUTION:_ The most common cause for this symptom is that the desired Hard Drive and Floppy Drive definitions were not swapped to define a Hard Drive Partition as the A: drive. Use BPCNFG (see 6.2), Menu 5 to exchange drives to the desired configuration. A similar situation may exist where a Hard Drive is activated immediately after booting when a Floppy drive is desired as the A: Drive.
|
||||
|
||||
**PROBLEM:** The computer seems to boot satisfactorily, but after a few programs or any program which executes a Warm Boot (or entering Control-C), the system goes into "Never-never Land" and must be reset.
|
||||
|
||||
_SOLUTION:_ This symptom is most often caused by an inability to access and load the Command Processor. This is most probably caused by assembling B/P Bios with the FASTWB equate in `DEF-xx.LIB` set to YES when the system contains no extended memory, or incorrect settings of the Bank Numbers. To check Bank Number settings, use the hidden function in BPCNFG, Menu 1 (see 6.2).
|
||||
|
||||
**PROBLEM:** When doing a Cold Boot from a Hard Drive (from Power up or Reset), the system goes to a Floppy Drive before displaying the initial sign on messages, and remains logged on the Floppy.
|
||||
|
||||
_SOLUTION:_ This is most often due to your forgetting to run the HDBOOT utility on the Hard Drive Boot system after applying it with BPSYSGEN. Normally, systems created with MOVxSYS contain a Floppy Disk Boot sector which will load the initial Operating System from a Floppy. HDBOOT (see 6.9) modifies this record on a specified Hard Drive Unit so that the Operating System is loaded from a Hard Drive. Run HDBOOT on the Desired Hard Drive, then use BPCNFG (see 6.2) to insure that the logical drives are positioned as desired (Menu 5).
|
||||
|
||||
**PROBLEM:** When Booting, the system console either doesn't display anything, or prints strange characters.
|
||||
|
||||
_SOLUTION:_ This is most often due to incorrect settings for the current Console, most probably the Data rate, or CPU Clock Frequency. Boot from a good system, then use BPCNFG (see 6.2) to adjust the settings on the problem system. Pay particular attention to Menu 1 (CPU Clock Rate) and Menu 2 (IOBYTE and Serial Port Data Rates).
|
||||
|
||||
**PROBLEM:** When running a fully-banked system with ZSDOS 2, some programs seem to "hang" or "lock up" the system on exit.
|
||||
|
||||
_SOLUTION:_ One of the most common sources of this symptom is with the application program where the author used code which assumes that the BDOS and Command Processor are of a certain size, or bear a fixed relationship to the addresses in page 0. You may experience this most often when using an IMG system built by answering YES to the Autosizing query in BPBUILD (see 6.1). To compensate for such ill-behaved programs, you may use a two-step build process as:
|
||||
|
||||
1. Use BPBUILD to create an IMG file answering YES to Autosizing on exit. This maximizes TPA placing the Resident Bios as high as possible in memory.
|
||||
|
||||
2. Execute BPBUILD again with an argument of the name you gave to the file just created above. This loads the definition from the IMG file. Immediately exit with a Carriage Return, and answer NO to Autosizing, and YES to placing system segments at standard locations. This procedure keeps the Bios address constant, but will move the starting addresses of BDOS and Command Processor down, if possible, to simulate "standard" sizes used in CP/M 2.2.
|
||||
|
||||
|
||||
1364
Doc/CPM/BPBIOS/BPBIOS_5_Programming.md
Normal file
1364
Doc/CPM/BPBIOS/BPBIOS_5_Programming.md
Normal file
File diff suppressed because it is too large
Load Diff
2579
Doc/CPM/BPBIOS/BPBIOS_6_Utilities.md
Normal file
2579
Doc/CPM/BPBIOS/BPBIOS_6_Utilities.md
Normal file
File diff suppressed because it is too large
Load Diff
37
Doc/CPM/BPBIOS/BPBIOS_7_ZSDOS2.md
Normal file
37
Doc/CPM/BPBIOS/BPBIOS_7_ZSDOS2.md
Normal file
@@ -0,0 +1,37 @@
|
||||
# 7 ZSDOS Version 2
|
||||
|
||||
Version 2 of ZSDOS is currently in a developmental phase. The version provided with this package is preliminary and should not be considered a final work. Be sure you back up any files which you don't mind sacrificing, and please let us know in as much detail as possible any problems you experience.
|
||||
|
||||
In addition to the ZSDOS Version call (Function 48) returning 20H signifying ZSDOS2, three new Operating System functions have been added. They are:
|
||||
|
||||
| Function 46 | Return Disk Free Space |
|
||||
| ---: | :--- |
|
||||
| Enter: | C = 46 (function #) |
|
||||
| | E = Drive # (A=0..P=15) |
|
||||
| Exit: | A = 0 if Ok, <>0 if Error |
|
||||
| | Disk Free Space in kilobytes is placed in DMA+0 (LSB) thru DMA+3 (MSB) |
|
||||
|
||||
This function returns Disk Free Space from fully-banked systems where the ALV buffers are not directly accessible by applications programs. It **MUST** be used to reliably determine free space since there is no way for programs to ascertain which System Bank (if more than one) contains the Allocation Bit Map. For most reasonably-sized systems, only the lower two or three bytes will be used, but four bytes are allocated to accommodate a maximally-sized system.
|
||||
|
||||
| Function | Return Environment Descriptor Address |
|
||||
| ---: | :--- |
|
||||
| Enter: | C = 49 (function #) |
|
||||
| Exit: | HL = Address of Env Desc. |
|
||||
|
||||
This function returns the address of a ZCPR 3.4 "type" Environment Descriptor needed in B/P Bios systems. Rather than rely on the Command Processor inserting the ENV address into application programs upon execution, this function may be used to reliably acquire the ENV address at any time.
|
||||
|
||||
| Function 152 | Parse File Name |
|
||||
| ---: | :--- |
|
||||
| Enter: | C = 152 (function #) |
|
||||
| | DE = Pointer to dest FCB |
|
||||
| | DMA --> start of parse string |
|
||||
| Exit: | A = Number of "?" in fn.ft |
|
||||
| | DE = points to delimiter |
|
||||
| | FCB+15 will be 0 if parse Ok, 0FFH if errors occurred |
|
||||
|
||||
This function may be used to replace Z3LIB library routines in a more robust manner and produce consequently smaller applications programs. It is fully compliant with ZCPR 3.4 parse specifications.
|
||||
|
||||
|
||||
## 7.1 NOTES Spring 2001
|
||||
|
||||
The versions of ZSDOS2 (the Banked Z-System DOS) and Z4x Banked Command Processor Replacement have been modified over the years. The manual may refer to specific versions, or by generic names. As of the Spring 2001 release under the GNU General Public License, Two versions of ZSDOS2 are provided; `ZS203.ZRL` which contains code for hashed directories, and `ZS227G,ZRL` which does not.
|
||||
10
Doc/CPM/BPBIOS/BPBIOS_8_ZCPR4.md
Normal file
10
Doc/CPM/BPBIOS/BPBIOS_8_ZCPR4.md
Normal file
@@ -0,0 +1,10 @@
|
||||
# 8 ZCPR Version 4
|
||||
|
||||
`Z40.ZRL` is a consolidation of ZCPR34 and many of the RCP features commonly in use, modified by the need to bank as much of the Command Processor as possible. When Z40 is used in a Fully-Banked system, you may not need much of, or any Resident Command Processor with your system. Z40 relys on ZSDOS2 and will **NOT** work without it since the Command Line Parser and disk free space calculations have been removed in favor of ZSDOS2 services. Additionally, the prompt line displays the time and will only function correctly if he ZSDOS2 clock is enabled. Comments on how these new System components work would be appreciated.
|
||||
|
||||
More complete documentation is provided in the `Z40.HLP` files included with the distribution diskettes, and a list of active functions is available with the H command at the prompt. To read the On-line help files, use `HELP.COM` available for downloading from any Z-Node.
|
||||
|
||||
|
||||
## 8.1 NOTES Spring 2001
|
||||
|
||||
The versions of ZSDOS2 (the Banked Z-System DOS) and Z4x Banked Command Processor Replacement have been modified over the years. The manual may refer to specific versions, or by generic names. As of the Spring 2001 release under the GNU General Public License, the latest version of the Z4x Processor Replacement is `Z41.ZRL` which features a small amount of tailoring. A new utility; **`CONFZ4.COM`** is available for this purpose.
|
||||
100
Doc/CPM/BPBIOS/BPBIOS_9_Glossary.md
Normal file
100
Doc/CPM/BPBIOS/BPBIOS_9_Glossary.md
Normal file
@@ -0,0 +1,100 @@
|
||||
# GLOSSARY
|
||||
|
||||
|
||||
|
||||
**Application Programs**
|
||||
|
||||
In contrast to utility programs (see), application programs or applications are larger programs such as word processors which function interactively with the user.
|
||||
|
||||
|
||||
|
||||
**BDOS**
|
||||
|
||||
Basic Disk Operating System. The machine-independent, but usually processor-dependent, program which controls the interface between application programs and the machine-dependent hardware devices such as printers, disk drives, clocks, etc. It also establishes the concept of files on media and controls the opening, reading, writing, and closing of such constructs.
|
||||
|
||||
|
||||
|
||||
**BGii**
|
||||
|
||||
BackGrounder ii from Plu*Perfect Systems, a windowing task-switching system for CP/M users with hard or RAM disks.
|
||||
|
||||
|
||||
|
||||
**BIOS**
|
||||
|
||||
Basic Input/Output System. Machine-dependent routines which perform actual peripheral device control such as sending and receiving characters to the console, reading and writing to disk drives, etc.
|
||||
|
||||
|
||||
|
||||
**Bit**
|
||||
|
||||
BInary digiT. An element which can have only a single on or off state.
|
||||
|
||||
|
||||
|
||||
**Bit Map**
|
||||
|
||||
An array of bits used to represent or map large arrays of binary information in a compact form.
|
||||
|
||||
|
||||
|
||||
**Boot**
|
||||
|
||||
The term used for the starting sequence of a computer. Generally applies to starting from a "Cold," or power-off state, and includes the loading of Operating System, and configuration steps.
|
||||
|
||||
|
||||
|
||||
**Byte**
|
||||
|
||||
A grouping of eight bits.
|
||||
|
||||
|
||||
|
||||
**CPR**
|
||||
|
||||
Command Processor Replacement. Replaces CCP (see below). Example: ZCPR
|
||||
|
||||
|
||||
|
||||
**CCP**
|
||||
|
||||
Console Command Processor. The portion of the operating system that interprets user's commands and either executes them directly or loads application programs from disk for execution. The CCP may be overwritten by applications, and is reloaded by the "Warm Boot" function of the BIOS.
|
||||
|
||||
|
||||
|
||||
**Checksum**
|
||||
|
||||
An value which arithmetically summarizes the contents of a series of memory locations, and used to check the current contents for errors.
|
||||
|
||||
|
||||
|
||||
**Clock Driver**
|
||||
|
||||
A software link between a Non-banked ZSDOS and the clock on your system. The clock driver allows ZSDOS and its utilities to read the clock which is normally inherent in the B/P Bios.
|
||||
|
||||
|
||||
|
||||
**Command Script**
|
||||
|
||||
Sometimes called simply scripts, command scripts allow you to create a single command which issues other commands to perform a unique set of actions. CP/M submit files are one kind of command script familiar to all CP/M users. ZCPR also offers more sophisticated types of scripts such as aliases and command files (e.g., ALIAS.CMD).
|
||||
|
||||
|
||||
|
||||
**DateStamper**
|
||||
|
||||
A software package developed by Plu*Perfect Systems to allow time and date stamping of files. The Boot System uses an external module in the file LDDS.COM to implement DateStamper, while ZSDOS2 automatically supports this stamping method. DateStamper is unique among file stampers for microcomputers for two reasons: first, it maintains all file stamps within a file; second, it maintains stamps for create, access, and modify time/date for each file.
|
||||
|
||||
|
||||
|
||||
**DDT**
|
||||
|
||||
Dynamic Debugging Tool. A utility distributed with CP/M 2.2 which can display, disassemble, or alter disk files or areas of memory using opcodes or hexadecimal values.
|
||||
|
||||
|
||||
|
||||
**DOS**
|
||||
|
||||
Disk Operating System. Often used term for the BDOS, but generally refers to the aggregate of CCP, BDOS and BIOS.
|
||||
|
||||
|
||||
|
||||
BIN
Doc/CPM/CPM Manual.pdf
Normal file
BIN
Doc/CPM/CPM Manual.pdf
Normal file
Binary file not shown.
BIN
Doc/CPM/CPM3 Command Summary.pdf
Normal file
BIN
Doc/CPM/CPM3 Command Summary.pdf
Normal file
Binary file not shown.
BIN
Doc/CPM/CPM3 Programmers Guide.pdf
Normal file
BIN
Doc/CPM/CPM3 Programmers Guide.pdf
Normal file
Binary file not shown.
BIN
Doc/CPM/CPM3 System Guide.pdf
Normal file
BIN
Doc/CPM/CPM3 System Guide.pdf
Normal file
Binary file not shown.
BIN
Doc/CPM/CPM3 Users Guide.pdf
Normal file
BIN
Doc/CPM/CPM3 Users Guide.pdf
Normal file
Binary file not shown.
BIN
Doc/CPM/NZCOM Users Manual.pdf
Normal file
BIN
Doc/CPM/NZCOM Users Manual.pdf
Normal file
Binary file not shown.
83
Doc/CPM/ReadMe.txt
Normal file
83
Doc/CPM/ReadMe.txt
Normal file
@@ -0,0 +1,83 @@
|
||||
***********************************************************************
|
||||
*** ***
|
||||
*** R o m W B W ***
|
||||
*** ***
|
||||
*** Z80/Z180 System Software ***
|
||||
*** ***
|
||||
***********************************************************************
|
||||
|
||||
This directory ("Doc/CPM") is part of the RomWBW System Software
|
||||
distribution archive. It contains documentation for the CP/M and
|
||||
CP/M work-alike operating system components of the system.
|
||||
|
||||
|
||||
CPM Manual ("CPM Manual.pdf")
|
||||
-----------------------------
|
||||
|
||||
The original DRI CP/M 2.x Operating System Manual. This should be
|
||||
considered the primary reference for system operation. The section
|
||||
on CP/M 2 Alteration can be ignored since this work has already been
|
||||
completed as part of the RomWBW distribution.
|
||||
|
||||
|
||||
CPM3 Command Summary ("CPM3 Command Summary.pdf")
|
||||
CPM3 Programmer's Guide ("CPM3 Programmers Guide.pdf")
|
||||
CPM3 System Guide ("CPM3 System Guide.pdf")
|
||||
CPM3 User's Guide ("CPM3 Users Guide.pdf")
|
||||
------------------------------------------------------
|
||||
|
||||
The original DRI CP/M 3.0 Operating System Documentation Set. This
|
||||
should be considered the primary reference for CP/M 3 system operation.
|
||||
|
||||
|
||||
NZCOM, Z3PLUS, and replace ZCPR3.3 Documentation
|
||||
------------------------------------------------
|
||||
|
||||
NZCOM operating system operation manual. ("NZCOM Users Manual.pdf")
|
||||
Z3PLUS operating system operation manual. ("Z3PLUS Users Manual.pdf")
|
||||
Z-System User Guide ("Z-System User Guide.pdf")
|
||||
ZCPR3.3 Users Guide ("ZCPR3.3 Users Guide.pdf")
|
||||
|
||||
|
||||
QP/M 2.7 Installation Guide and Supplements ("qpm27.pdf")
|
||||
QP/M 2.7 Interface Guide ("qdos27.pdf")
|
||||
QP/M 2.7 Features and Facilities ("qcp27.pdf")
|
||||
--------------------------------------------
|
||||
|
||||
Official documentation set for QP/M 2.7 from original QP/M distribution.
|
||||
|
||||
|
||||
ZCPR Manual ("ZCPR Manual.pdf")
|
||||
-------------------------------
|
||||
|
||||
ZCPR is the command proccessor portion of Z-System. This is the
|
||||
manual for ZCPR 1.x as included in RomWBW. The installation
|
||||
instructions can be ignored since that work has already been
|
||||
completed as part of the RomWBW distribution.
|
||||
|
||||
ZCPR D&J Manual ("ZCPR-DJ.doc")
|
||||
-------------------------------
|
||||
|
||||
ZCPR D&J User Manual. This manual supplements the ZCPR Manual.
|
||||
|
||||
|
||||
ZSDOS Manual ("ZSDOS Manual.pdf")
|
||||
ZSDOS Programmer's Manual ("ZSDOS Programmers Manual.pdf")
|
||||
---------------------------------
|
||||
|
||||
ZSDOS is the DOS portion of Z-System. This is the manual for ZSDOS
|
||||
1.x as included in RomWBW. The installation instructions can be
|
||||
ignored since that work has already been completed as part of the
|
||||
RomWBW distribution.
|
||||
|
||||
The ZSDOS Programmer's Manual is also included courtesy of Wayne
|
||||
Hortensius and Randy Merkel. This manual includes documentation of the
|
||||
ZSDOS BDOS API enhancements.
|
||||
|
||||
ZPM3 ("ZPM3.txt")
|
||||
-----------------
|
||||
|
||||
A Z80 coded CP/M 3.0 compatible BDOS replacement with ZCPR support.
|
||||
This minimal documentation is all that is provided with ZPM3.
|
||||
|
||||
-- WBW 8:38 AM 6/6/2025
|
||||
BIN
Doc/CPM/Z-System Users Guide.pdf
Normal file
BIN
Doc/CPM/Z-System Users Guide.pdf
Normal file
Binary file not shown.
6773
Doc/CPM/Z3PLUS Users Manual.pdf
Normal file
6773
Doc/CPM/Z3PLUS Users Manual.pdf
Normal file
File diff suppressed because it is too large
Load Diff
BIN
Doc/CPM/ZCPR Manual.pdf
Normal file
BIN
Doc/CPM/ZCPR Manual.pdf
Normal file
Binary file not shown.
BIN
Doc/CPM/ZCPR3.3 User Guide.pdf
Normal file
BIN
Doc/CPM/ZCPR3.3 User Guide.pdf
Normal file
Binary file not shown.
483
Doc/CPM/ZPM3.txt
Normal file
483
Doc/CPM/ZPM3.txt
Normal file
@@ -0,0 +1,483 @@
|
||||
|
||||
Z P M 3 by Simeon Cran
|
||||
========================
|
||||
|
||||
A Z80 coded CP/M 3.0 compatible BDOS replacement.
|
||||
|
||||
The first public release: 27/3/92
|
||||
This document dated: 16/6/92
|
||||
|
||||
Distributed at: Z-Node 62 (Perth, Western Australia)
|
||||
V21,V22,V22bis 09 450 0200
|
||||
|
||||
|
||||
WELCOME TO ZPM3
|
||||
~~~~~~~~~~~~~~~
|
||||
Welcome to the best CP/M compatible operating system for Z80
|
||||
based computers with banked memory. The best? Yes, we believe so.
|
||||
CP/M 3.0 has had bad press, but the fact is that it is faster
|
||||
than CP/M 2.2 ever was, and it offered more integrated
|
||||
facilities. Perhaps it was all the Z80 replacement BDOSes for
|
||||
CP/M 2.2 which stole the limelight from CP/M 3.0, or was it just
|
||||
that few computers had the required banked memory?
|
||||
|
||||
Whatever the reason for CP/M 3.0's lack of success in the
|
||||
marketplace, there are still plenty of users who will stand by
|
||||
its wonderful facilities and speed. For those users ZPM3 provides
|
||||
the long awaited Z80 coded update.
|
||||
|
||||
ZPM3 offers all the good things that CP/M 3.0 does, and then it
|
||||
offers more. Because ZPM3 is written in Z80 code rather than the
|
||||
8080 code of CP/M 3.0, it can do everything that CP/M 3.0 does,
|
||||
but in much less space. With the extra space recovered, ZPM3
|
||||
packs in a number of new facilities. Yet the whole package fits
|
||||
in exactly the same space as CP/M 3.0 so you can directly replace
|
||||
your old CP/M 3.0 BDOS with ZPM3 without a worry.
|
||||
|
||||
ZPM3 is also fast. Faster, in fact, than CP/M 3.0. This is
|
||||
possible because the rich Z80 instruction set allows many
|
||||
algorithms to be implemented more efficiently. In addition, the
|
||||
extra space available in ZPM3 has been put to use to further
|
||||
optimise the code. Lots of small optimisations smooth the
|
||||
execution flow, so ZPM3 becomes the fastest operating system on
|
||||
most banked CP/M computers.
|
||||
|
||||
|
||||
THE FEATURES
|
||||
~~~~~~~~~~~~
|
||||
ZPM3, in addition to complete CP/M 3.0 compatibility, offers the
|
||||
following features:
|
||||
|
||||
|
||||
Random Read Bug fixed.
|
||||
++++++++++++++++++++++
|
||||
Maybe you didn't know, but CP/M 3.0 has a bug. It affects random
|
||||
reads under very specific circumstances, and can result in a
|
||||
program thinking that you don't have some pieces of data in a
|
||||
file when in fact you do. The bug would occur very, very rarely,
|
||||
but it is real. ZPM3 finally squashes it.
|
||||
|
||||
|
||||
Protected SCB User code
|
||||
+++++++++++++++++++++++
|
||||
The System Control Block of CP/M 3.0 was a revolution at the
|
||||
time. ZCPR has a system environment and most other operating
|
||||
systems have other similar structures, but the SCB of CP/M 3.0
|
||||
was one of the very first.
|
||||
|
||||
Unfortunately, Digital Research never properly documented it, and
|
||||
some programmers found things out about it that weren't quite
|
||||
true and started programming accordingly. As well, because it is
|
||||
available in the TPA bank, runaway programs can overwrite it
|
||||
causing problems.
|
||||
|
||||
Mostly though, the SCB will survive, or at least any problems
|
||||
will be so obvious that the user will realise that a crash has
|
||||
occurred and will reboot. A real problem exists with the CP/M 3.0
|
||||
code however when the user value is written over with a value
|
||||
above 15. Many programs now directly write to this byte, and if
|
||||
they put a value in that is above 15, all sorts of havoc can
|
||||
happen with the disk system. Actually, CP/M 3.0 will handle user
|
||||
areas above 15 with this method, and all seems ok until the
|
||||
operating system mistakes one of these directory entries as an
|
||||
XFCB. Simply put, user areas above 15 must not be used with CP/M
|
||||
3.0.
|
||||
|
||||
ZPM3 has code which prevents these problems, making the system
|
||||
even more stable.
|
||||
|
||||
|
||||
Obsoleted Trap system.
|
||||
++++++++++++++++++++++
|
||||
One of the problems of the banked operating system was that it
|
||||
was possible to redirect the BIOS to code below common memory, in
|
||||
which case the banked BDOS could not access it. One solution is
|
||||
to call all BIOS code from common memory, but this involves a
|
||||
bank switch for every BIOS call, and this slows things down
|
||||
considerably.
|
||||
|
||||
CP/M 3.0 got around the problem by providing special code just
|
||||
below the SCB. If you redirected the BIOS, you also had to change
|
||||
this code which caused a bank switch when your new BIOS routine
|
||||
was called. When you removed the redirection, you also had to
|
||||
restore the special code.
|
||||
|
||||
This system has major drawbacks. For a start, if you redirect the
|
||||
BIOS, then another program redirects your redirection, then you
|
||||
remove your first redirection (along with the special code), the
|
||||
bank switch won't happen for the second redirection and the
|
||||
system will crash.
|
||||
|
||||
If a CP/M 2.2 program tried to do the redirection, it would know
|
||||
nothing about CP/M 3.0 and would not adjust the special code, so
|
||||
a crash would result in that case too.
|
||||
|
||||
The special code was called the "Trap System" as it was meant to
|
||||
trap redirection (as long as you set the trap). ZPM3 has
|
||||
eliminated the need for the traps. They are still there, and
|
||||
programs can still fiddle with them, but it doesn't matter how
|
||||
they are set, they are ignored. There is simply no need for them
|
||||
anymore. And this has been achieved without a performance
|
||||
penalty. In fact, in the case of a program which sets the traps
|
||||
but forgets to restore them, performance is now much better.
|
||||
|
||||
|
||||
Semi-Permanent Read Only status for drives.
|
||||
+++++++++++++++++++++++++++++++++++++++++++
|
||||
In recent years, a trend in CP/M 2.2 is to make drives which have
|
||||
been set read only to remain that way until explicitly changed by
|
||||
function 37. ZPM3 now adopts this logic. Previously a control-C
|
||||
would return a read only drive to read write. The advantage is
|
||||
that a program can now make a drive read only for a session and
|
||||
know that it will stay that way.
|
||||
|
||||
|
||||
ZCPR compatible function 152
|
||||
++++++++++++++++++++++++++++
|
||||
Function 152 is the CP/M 3.0 parser. It was a great innovation at
|
||||
the time as parsing is one of the more tedious aspects of
|
||||
programming for CP/M. Unfortunately, almost as soon as it
|
||||
appeared, it was made obsolete by the fact that it didn't handle
|
||||
references to user number (DU references). A line such as
|
||||
A:FILE.TYP would be correctly parsed, but A3:FILE.TYP would not.
|
||||
CP/M 3.0 programs would often parse the drive and user
|
||||
separately, then give function 152 the line without the DU:
|
||||
reference. All this extra work should not have been necessary if
|
||||
CP/M 3.0 had included user number parsing.
|
||||
|
||||
ZPM3 parses the user number, and goes even further by handling
|
||||
named directories for ZCPR. This is possible as long as you set a
|
||||
special word in the SCB which tells ZPM3 where to find the ZCPR
|
||||
system environment descriptor. ZCCP, a companion CCP for ZPM3,
|
||||
handles this automatically, but for Z3PLUS users, a special
|
||||
utility is available which automatically sets this word.
|
||||
|
||||
The result is that CP/M 3.0 programs will not balk at DU:
|
||||
references and ZPM3 aware programs can use the full DU: and DIR:
|
||||
facilities of function 152. It has also made the brilliant ZCCP
|
||||
code possible.
|
||||
|
||||
|
||||
New Functions 54 and 55
|
||||
+++++++++++++++++++++++
|
||||
Datestamps in CP/M 3.0 are wonderful, but difficult to
|
||||
manipulate. Two new functions make them easier to handle and at
|
||||
the same time give compatibility to Z80DOS aware programs.
|
||||
|
||||
Function 54 (Get Stamp) returns a Z80DOS compatible datestamp.
|
||||
Any program (such as many directory programs) which recognise the
|
||||
Z80DOS standard can make use of function 54. There is only one
|
||||
slight difference between Z80DOS datestamps and ZPM3's which you
|
||||
should be aware of. Z80DOS will return a correct datestamp after
|
||||
any successful open or search of any extent. ZPM3 can only return
|
||||
a correct datestamp after a successful open or search of the
|
||||
first extent of the file. This is because CP/M 3.0 datestamps are
|
||||
only saved for the first extents of each file, in order to
|
||||
provide the highest performance.
|
||||
|
||||
Even more interesting is Function 55 (Use Stamp) which provides a
|
||||
mechanism for changing datestamps on files. Trying to do this
|
||||
with CP/M 3.0 was virtually impossible because it involved direct
|
||||
sector writes. With Function 55 you can simply set the stamp and
|
||||
then write.
|
||||
|
||||
|
||||
Wheel protected files
|
||||
+++++++++++++++++++++
|
||||
If you are using a ZCPR system (ZCCP or Z3PLUS), ZPM3 has access
|
||||
to the wheel byte and supports wheel protected files. Such files
|
||||
act normally if the wheel is set (signifying a priveleged user),
|
||||
but if the wheel is not set, the files can not be changed. This
|
||||
is of most benefit to BBS systems. The implementation is
|
||||
virtually the same as most current Z80 CP/M 2.2 compatible
|
||||
BDOSes.
|
||||
|
||||
|
||||
Better error messages
|
||||
+++++++++++++++++++++
|
||||
CP/M 3.0 introduced the best error messages that CP/M had ever
|
||||
had. ZPM3 goes further. The main difference you will notice is
|
||||
that the user number as well as the drive is shown in the error
|
||||
message. This is invaluable in helping you identify which file
|
||||
might have caused a problem.
|
||||
|
||||
|
||||
Function 10 history buffer and improved editing.
|
||||
++++++++++++++++++++++++++++++++++++++++++++++++
|
||||
Function 10 is used by the CCP to input command lines. Many other
|
||||
programs use function 10 for input.
|
||||
|
||||
CP/M 3.0 introduced a history buffer for function 10. You press
|
||||
control-W and you were returned the last command. It is a great
|
||||
facility, but because it only remembers one command it is rather
|
||||
limited. There have been RSXes written which give a much larger
|
||||
history buffer, but RSXes take up extra program memory so are
|
||||
undesirable.
|
||||
|
||||
ZPM3 gives a large (approximately 250 bytes) history buffer which
|
||||
can store multiple commands. It also makes very intelligent use
|
||||
of the buffer so that identical commands are not stored twice,
|
||||
and commands of less than three characters are not stored. The
|
||||
history buffer takes up no additional memory, and is always
|
||||
available.
|
||||
|
||||
For security, it is possible to clear the history buffer so that
|
||||
other users can not see what commands you have used.
|
||||
|
||||
The ZPM3 history buffer feature is so good, that for many users,
|
||||
the ZPM3 upgrade is completely justified by it.
|
||||
|
||||
As part of the history buffer system, ZPM3 also offers a facility
|
||||
called Automatic Command Prompting. This can be disabled, or can
|
||||
be made switchable from the keyboard. When it is on, ZPM3 tries
|
||||
to fill in the rest of your command based on what commands you
|
||||
used most recently. It is like magic, and can save you typing out
|
||||
complicated commands many times. In effect, it looks through the
|
||||
history buffer for you and finds the command it thinks you want.
|
||||
As you keep typing, if it turns out that the command doesn't
|
||||
match anymore, it will try to match another command, and if it
|
||||
can't, it lets you make the command by yourself. This facility is
|
||||
quite amazing to watch.
|
||||
|
||||
And to integrate the history buffer and the automatic command
|
||||
prompting, function 10 has the best command line editing you'll
|
||||
find anywhere. Most of the control keys do something when you are
|
||||
editing a function 10 line, and for the most part they mimic the
|
||||
standard WordStar/NewWord/ZDE functions. You can jump to
|
||||
different words in the command, delete individual words, delete
|
||||
individual letters, insert letters, and a whole lot more.
|
||||
|
||||
|
||||
Here is a list of what the various control keys do for function
|
||||
10:
|
||||
|
||||
A Move left one word
|
||||
B Go to the beginning or end of the line
|
||||
C Warm boot if at start of line, otherwise nothing
|
||||
D Go right one character
|
||||
E Go backwards one command in the history buffer
|
||||
F Go right one word
|
||||
G Delete current character
|
||||
H Destructive backspace
|
||||
I
|
||||
J Enter line
|
||||
K Delete all to the right
|
||||
L
|
||||
M Enter line
|
||||
N
|
||||
O
|
||||
P Toggle printing
|
||||
Q Toggle automatic command prompting (if enabled)
|
||||
R
|
||||
S Go left one character
|
||||
T Delete current word
|
||||
U Add current line to history buffer
|
||||
V Clear line and delete from history buffer
|
||||
W Go forwards one command in the history buffer
|
||||
X Delete all to the left
|
||||
Y Clear the whole line
|
||||
Z
|
||||
|
||||
|
||||
CPMLDR.REL bug fixed.
|
||||
+++++++++++++++++++++
|
||||
If you have ever tried to use the CPMLDR.REL code supplied with
|
||||
CP/M 3.0 to load a CPM3.SYS file larger than 16k, you have
|
||||
probably come across the CPMLDR.REL bug. The computer probably
|
||||
crashed, and you were left wondering what you did wrong in your
|
||||
bios.
|
||||
|
||||
Well CPMLDR.REL has a bug. To solve this for you ZPM3 comes with
|
||||
ZPM3LDR.REL which directly replaces CPMLDR.REL. It is also
|
||||
somewhat better in that all the messages, and the fcb for loading
|
||||
CPM3.SYS, are at the start of the file along with plenty of spare
|
||||
room. As a result you can easily patch the signon and error
|
||||
messages to say whatever you like and even change the FCB to load
|
||||
a file called something other than CPM3.SYS.
|
||||
|
||||
|
||||
|
||||
|
||||
All About the Random Read Bug.
|
||||
==============================
|
||||
Never heard of it? Well it's there in CP/M 3.0. I spent a lot of
|
||||
time trying to work out what it was and just why it was
|
||||
happening, and if you are interested, here are the details.
|
||||
|
||||
CP/M 3.0 uses the Record Count byte of an active FCB a little
|
||||
differently from the way CP/M 2.2 does. It is mentioned in the
|
||||
CP/M 3.0 manuals that the record count may contain numbers
|
||||
greater than 128, but in such a case it implies that the record
|
||||
count is really 128. CP/M 2.2 would not return record counts
|
||||
greater than 128.
|
||||
|
||||
The reason for the use of the record count in this way is to help
|
||||
speed up some of the logic used to find records in a file. It
|
||||
works very well for sequential access. When it comes to random
|
||||
access, the system has some failings.
|
||||
|
||||
The idea behind CP/M 3.0's unusual use of the record count is to
|
||||
keep the record count of the last logical extent of the current
|
||||
physical extent always in the Record Count byte. When accessing
|
||||
extents before the last one, bit 7 of the byte is set. That way
|
||||
it will always be at least 128 for logical extents before the
|
||||
last (which CP/M 3.0 translates to mean equal to 128), and the
|
||||
lower 7 bits are used as convenient storage for the record count
|
||||
of the last logical extent. This is particularly convenient
|
||||
because it means there is no need to go and read the directory
|
||||
entry again when it comes time to read the last logical extent.
|
||||
|
||||
I hope you have followed that! In sequential access, this scheme
|
||||
is great. The problem occurs with random access. In this case it
|
||||
is possible to access a logical extent which has no records in
|
||||
it. This could be any logical extent past the last one. In such a
|
||||
case the record count must be returned as 0 (which is correct).
|
||||
If we then go back to a previous logical extent in the same
|
||||
physical extent, CP/M 3.0 gets confused and assumes that there
|
||||
must be 128 records in that extent because the one we just came
|
||||
from had no records and we are now accessing an earlier extent.
|
||||
You're probably well and truly lost by now!
|
||||
|
||||
Anyhow, the assumption that CP/M 3.0 makes is quite wrong. The
|
||||
record count ends up being set to 128, a read is allowed to go
|
||||
ahead as if nothing was wrong, no error is returned, and the
|
||||
record count remains incorrectly set until a different physical
|
||||
extent is opened. The result could be chaos, but mostly it just
|
||||
means that a program returns the wrong information.
|
||||
|
||||
Remember, a logical extent is always 16k. A physical extent can
|
||||
be a multiple of 16k and is all the data described by one
|
||||
directory entry. If your system has physical extents which are
|
||||
16k, you would never have the problem because a new physical
|
||||
extent would be properly opened for every new logical extent that
|
||||
was accessed.
|
||||
|
||||
Typically though, a physical extent is 32k, so it holds 2 logical
|
||||
extents. The problem won't arise until the file grows past the
|
||||
32k mark in such a case. And when the file gets over 48k the
|
||||
problem can't occur again until it gets over 64k... and so on.
|
||||
Even then, it can only happen if reads are attempted to
|
||||
particular extents in a particular order. So you shouldn't be too
|
||||
surprised if the bug hasn't been too noticeable to you.
|
||||
|
||||
ZPM3 squashes the bug once and for all by using the correct
|
||||
logic. In the situation where the bug would normally occur, ZPM3
|
||||
makes sure it gets the correct record count information, and the
|
||||
reads return the correct record count every time.
|
||||
|
||||
If you are interested in seeing a demonstration of the bug in
|
||||
action (on CP/M 3.0) and comparing it with ZPM3, there is a file
|
||||
floating around various bulletin boards which contains
|
||||
demonstrations for the bug and an RSX to fix it. The RSX is a
|
||||
less than perfect way of overcoming the bug, although it seems to
|
||||
work. However, now that you have ZPM3, you don't need to worry.
|
||||
|
||||
|
||||
|
||||
|
||||
Other things you should know about ZPM3
|
||||
=======================================
|
||||
ZPM3 has worked on EVERY CP/M 3.0 system tried so far except one.
|
||||
This is a Bondwell computer, and as yet it isn't clear why it
|
||||
won't work. I will study the source code of its BIOS and come up
|
||||
with a fix shortly.
|
||||
|
||||
The MAKEDOS.COM utility is not perfect (as mentioned previously)
|
||||
and it seems that nobody has managed to get it to work with the
|
||||
Commodore C128 system. You must use the conventional method for
|
||||
installing ZPM3 on such systems.
|
||||
|
||||
If you have a computer that ZPM3 will not install on with MAKEDOS
|
||||
and you do not have access to the files required to do a
|
||||
conventional install, please contact me. I am interested in
|
||||
making ZPM3 as universal as possible and will help you to install
|
||||
it on your system.
|
||||
|
||||
The ESCAPE key is ignored by function 10. There has been some
|
||||
lively discussion about this but the decision is final: it stays
|
||||
ignored. Remember what function 10 is for and you will understand
|
||||
why I made it ignore the ESCAPE key. The argument against this
|
||||
has been from people who control their terminals from the command
|
||||
line. Apparently some people type in an escape sequence at the
|
||||
command line (which CP/M 3.0 will not output correctly anyhow
|
||||
(converting the escape character to ^[)) then press return to
|
||||
have the CCP echo back the line including the escape character.
|
||||
|
||||
Sorry folks, that is a KLUDGE in my books! Anybody using Z-System
|
||||
would of course use an ALIAS and ECHO to do this properly, but
|
||||
for those who will continue to complain that I have sacrificed
|
||||
CP/M 3.0 compatibility I am now including ECHOTERM.COM to solve
|
||||
your problems. Run it and whatever you type will be sent to the
|
||||
terminal correctly after you press RETURN. Press RETURN twice to
|
||||
exit the program.
|
||||
|
||||
And a reminder that the ability to put control characters into
|
||||
function 10 lines was always limited by the fact that some
|
||||
control keys were used to edit the command line. CP/M 3.0 added
|
||||
even more, and ZPM3 uses virtually all the control keys. The few
|
||||
that aren't used are ignored, and this is in fact a FEATURE which
|
||||
guarantees that unusable characters can't get into function 10
|
||||
lines by accident.
|
||||
|
||||
|
||||
|
||||
|
||||
LEGALS and SUCH
|
||||
===============
|
||||
The ZPM3 package is supplied free of charge, on the condition
|
||||
that you don't use it to make money. If you want to use it
|
||||
commercially you must contact me to get the OK (and negotiate our
|
||||
fee).
|
||||
|
||||
If you find anyone (except myself) charging money for ZPM3,
|
||||
please inform me!
|
||||
|
||||
Nobody is making any guarantees about this software. None at all.
|
||||
If it causes your house to burn down, or a divorce, or just a bad
|
||||
day, this is unfortunate, regrettable, but there is nothing that
|
||||
I can or will do about it. You have been warned.
|
||||
|
||||
The ZPM3 package must only be distributed in the form that you
|
||||
found it. Do not change or add anything. Don't even change it
|
||||
into a different type of archive. Just leave it alone. However
|
||||
you are free to distribute it to as many places and people that
|
||||
you can. Just don't charge for it.
|
||||
|
||||
|
||||
|
||||
If in using ZPM3 you find that it doesn't act as described,
|
||||
please forward the details to me so that either the ZPM3 code or
|
||||
the documentation can be changed. If you would like further
|
||||
details, please forward your specific questions to me. SJC.
|
||||
|
||||
|
||||
|
||||
|
||||
As a service to all our ZPM3 fans, the latest version of the ZPM3
|
||||
package can now be ordered. At this stage we can only supply IBM
|
||||
formatted 3.5 inch 720k disks, however if you are keen enough
|
||||
that shouldn't matter. ZPM3 remains free, however this service
|
||||
will cost you $15 Australian (for the disk, copying, postage and
|
||||
packing) to most places in the Western World (others by
|
||||
arrangement).
|
||||
|
||||
This is a good way to guarantee you have the latest version, and
|
||||
to guarantee that your package has not been corrupted by some
|
||||
unscrupulous person.
|
||||
|
||||
When we fill your order, we will make sure to include the latest
|
||||
demonstration copy of MYZ80 - the fastest and best Z80 emulator
|
||||
for IBM AT (and better) compatibles. MYZ80 can run ZPM3 with
|
||||
ease. It also handles ZCPR and CP/M 2.2. And yes, we do mean
|
||||
FASTEST.
|
||||
|
||||
Send your international money order to:
|
||||
|
||||
Software by Simeon
|
||||
ZPM3 Package
|
||||
2 Maytone Ave
|
||||
Killara NSW
|
||||
Australia 2071
|
||||
|
||||
Your order will be promptly filled.
|
||||
|
||||
BIN
Doc/CPM/ZSDOS Programmers Manual.pdf
Normal file
BIN
Doc/CPM/ZSDOS Programmers Manual.pdf
Normal file
Binary file not shown.
BIN
Doc/CPM/qcp27.pdf
Normal file
BIN
Doc/CPM/qcp27.pdf
Normal file
Binary file not shown.
BIN
Doc/CPM/qdos27.pdf
Normal file
BIN
Doc/CPM/qdos27.pdf
Normal file
Binary file not shown.
BIN
Doc/CPM/qpm27.pdf
Normal file
BIN
Doc/CPM/qpm27.pdf
Normal file
Binary file not shown.
@@ -1,3 +1,467 @@
|
||||
Version 3.6
|
||||
-----------
|
||||
- RDG: Added VDA driver for Xosera FPGA-based VDC
|
||||
- MGG: Added COBOL language disk image
|
||||
- WDC: Added config options to PCF driver
|
||||
- WBW: Enabled dynamic CPU speed update on LCD screen
|
||||
- WBW: Improve LPT driver boot messaging when not detected (per Robb Bates)
|
||||
- WBW: Correct DS1307 boot date/time display (per Tadeusz Pycio)
|
||||
- WBW: Add -DELAY option to TUNE app (per Robb Bates)
|
||||
- RDG: Add online documentation site
|
||||
- WBW: Added enhanced Hi-Tech C Compiler files from Ladislau Szilagyi
|
||||
- WBW: Added boundary check to ram/rom disk driver
|
||||
- WBW: Per Peter Onion, switch KERMIT default file xfer mode to binary
|
||||
- J?L: Source for ZSDOS2 and BPBIOS Utilities (from disassembly)
|
||||
- WBW: Support ROM-based font storage
|
||||
- MAP: New Slice Inventory Rom App "S" display bootable slices, during boot
|
||||
- MAP: Device Inventory moved from HBIOS to Rom App, saving >1k space in HBIOS
|
||||
- MAP: Added disk image for all Infocom text adventure Games
|
||||
- M?R: Fixed formatting issue with SLABEL where Slice # < 10
|
||||
- WBW: Improved image creation process to allow user defined aggregates
|
||||
- WBW: Implemented config driven slice name and system image specification
|
||||
- D?N: Added native USB driver support (keyboard, floppy, mass storage)
|
||||
- MGG: Added sample program source files for all language disk iamges
|
||||
- WBW: Added support for S100 Dual CF Interface
|
||||
- WBW: Added support for S100 ESP32 SD Interface
|
||||
- MAP: User guide. Reorder sections around disk formatting
|
||||
- R?M: Randy Merkel provided ZSDOS Programmer's Manual as translated by Wayne Hortensius
|
||||
- WBW: Updated Cowgol disk image with latest COWFIX.COM from Ladislau Szilagyi
|
||||
- WBW: Preliminary support for S100 Computers Z80 CPU
|
||||
- HJB: Added MSX platform
|
||||
- M?R: Update Timer app with "zero" option
|
||||
- HJB: Update PPIDE driver, add support for MSX BEER IDE interface
|
||||
- HJB: Added loader for MSX
|
||||
- HJB: Added IDE driver master media detect option
|
||||
- WBW: Add support for S100 Serial I/O DLP Serial connection
|
||||
- P?D: Generate compressed ROM for EaZyZ80 512
|
||||
|
||||
Version 3.5.1
|
||||
-------------
|
||||
- WBW: Fix CPMLDR.SYS & ZPMLDR.SYS for SYSCOPY (reported by Guido Santer)
|
||||
- MAP: Enhanced SLR Tools Disk Image with Plus versions
|
||||
- WBW: Add missing BCLOAD file to MS BASIC Compiler Disk Image (reported by Marshall Gates)
|
||||
- WBW: Doc improvements (per Fraser and Rob Gowin)
|
||||
- WBW: Correct ZMP application crash
|
||||
- MAP: Contribution of the SLABEL.COM tool for displaying and changing slice labels.
|
||||
- MAP: Hardware documentation, Significant new content added with project links.
|
||||
|
||||
Version 3.5
|
||||
-----------
|
||||
- M?F: Fix for hours display in HBRTC application
|
||||
- M?F: Fix for assembly error in DS1501RTC driver
|
||||
- WBW: Add VT-100 graphics char selection to Propeller firmware
|
||||
- WBW: Allow all lines of VGA display to be used on Propeller firmware
|
||||
- WBW: Allow front panel LED/Switch bits to be inverted in config
|
||||
- WBW: Add API to expose application banks available
|
||||
- WBW: Added console takeover at boot loader prompt
|
||||
- L?N: Fixed Propeller font vertical line character to align properly
|
||||
- L?S: EF9345 video display controller driver
|
||||
- WBW: Added Cowgol disk image based on the work of Ladislau Szilagyi
|
||||
- WBW: Added support for CP/NET on Duodyne Disk I/O
|
||||
- DDW: Added support for Duodyne Media board
|
||||
- WBW: Auto restore TMS video on user reset (CP/M warm boot)
|
||||
- L?B: Added support for NABU w/ RomWBW Option Board
|
||||
- MAP: Reorganization of Doc directory introducing subfolders
|
||||
- WBW: Upgraded BBCBASIC to v5.00
|
||||
- W?S: Updated FLASH utility to v1.3.9
|
||||
- WBW: Support RCBus PS/2 Keyboard (EP/Sally)
|
||||
- M?R: Update Timer app to display output in decimal
|
||||
- WBW: Preliminary support for S100 FPGA Z80 platform
|
||||
- WBW: Added simple serial (SSER) driver
|
||||
- WBW: Added preliminary support for S100 FPGA Z80 SD Cards
|
||||
- M?R: Consolidated ROM Applications document into the Applications document
|
||||
- M?R: Reviewed and substantially improved the Applications document
|
||||
- WBW: Added support for DS1305 RTC on S100 FPGA Z80
|
||||
- WBW: Added support for Les Bird's RCBus Graphics/Sound/Joystick module
|
||||
- WBW: Added support for Les Bird's Dual 16C550 UART module
|
||||
- WBW: Refactor UART driver for more flexible configuration
|
||||
- M?R: Added hour/minute/second display to timer app
|
||||
- WBW: Substantial customization of NZ-COM disk image
|
||||
- WBW: Refactor build post-processing (ZRC, ZZRCC, etc.)
|
||||
- MAP: Improved section Real Time Clock in User Guide document
|
||||
- WBW: Support for Hitachi HD44780-based LCD display
|
||||
- DRJ: Added support for Genesis STD Bus Z180 platform
|
||||
- MAP: Improved section Disk Management in User Guide document
|
||||
- WBW: Add CPU speed selection for HEATH platform to HBIOS
|
||||
- WBW: Add Warm/Cold reboot options to CPUSPD utility
|
||||
- D?N: Added support for eZ80 CPU
|
||||
- MAP: Contributed COPYSL utility that allows disk slices to be copied
|
||||
- MAP: Added new HBIOS function EXT_SLICE, extended disk slice info
|
||||
- MAP: ROMLDR now uses EXT_SLICE to get Slice Sector for boot
|
||||
- MAP: CBIOS now uses EXT_SLICE during drive selection
|
||||
- MAP: CPM3 Boot Loader, and BIOS (drive select) now use EXT_SLICE
|
||||
- M?R: Added REBOOT application
|
||||
- MAP: Significant improvement in Disk Catalog document
|
||||
- MAP: Added Disk Image for the Z3PLUS (Z-System for CP/M-Plus) os.
|
||||
- H?H: Fix XModem 12.3 WRERR to put CAN char in proper register to send.
|
||||
- MAP: Added support for dynamic HBIOS config via (RTC) NVRAM
|
||||
- MAP: Added boot application to allow config of NVRAM options
|
||||
- MAP: Configuration of autoboot disk/app added to NVRAM config
|
||||
- WBW: Autoboot is now handled in separate prompt during RomWBW startup
|
||||
- MAP: Added additional tools (Linker/Disasembler) to the Z80ASM Disk Image
|
||||
- PMS: Support interrupt-driven PS2 Keyboard Interface
|
||||
- D?M: Added NetBoot support for Duodyne
|
||||
- WBW: Add options to TUNE/HBIOS to force detection of MSX and RC AY/YM standard PSG ports
|
||||
- MAP: Added /B=OPTIONS for automated drive assignment to ASSIGN.COM
|
||||
- WBW: Added TE Editor (Ladislau Szilagyi)
|
||||
- WBW: Refresh Cowgol disk image (Ladislau Szilagyi)
|
||||
|
||||
Version 3.4
|
||||
-----------
|
||||
NOTE: Changes require HBIOS/CBIOS/Apps sync, version bump to 3.4 to ensure integrity
|
||||
- WBW: Device type number moved from upper nibble to full byte
|
||||
- A?C: Support for EP ITX-Mini Z180 Platform
|
||||
- M?R: Significant improvement in User Guide document
|
||||
- J?P: Preliminary support for Monsputer (MON)
|
||||
- JLC: Standardize TMS driver memory map for compatibility
|
||||
- WBW: Improved IDE device detection
|
||||
- WBW: Fixed decompression when run on Z280
|
||||
- K?B: WDATE generic HBIOS date/time utility
|
||||
- WBW: Create new DSKY framework with simple driver style interface
|
||||
- JBL: Added ColecoVision config in TMS driver
|
||||
- WBW: Added support for interrupt mode 1 on Z180
|
||||
- WBW: Added S100 platform
|
||||
- WBW: Added Duodyne platform
|
||||
- WBW: Incorporated John Monahan's S100 Monitor in S100 platform build
|
||||
- WBW: Support ESP32 on Duodyne
|
||||
- M?C: Fixed port specification when using XM.COM send transfers
|
||||
- PMS: Support for Duodyne DMA
|
||||
- WBW: Added Serial ROM (SROM.COM) utility
|
||||
- WBW: Support S100 Propeller Console
|
||||
- SCC: Added support for SC700
|
||||
- WBW: Added Heath H8 platform
|
||||
- D?J: Enhanced build to run on Raspberry Pi 4
|
||||
- WBW: Complete overhaul of ROMless boot operation
|
||||
- WBW: Prevent access to slices outside of partition
|
||||
- T?P: Contributed the HTALK utility
|
||||
- WBW: CTS stall detection
|
||||
- W?S: Updated FLASH utility to v1.3.7
|
||||
- L?N: Updated UNARC to new OS universal version
|
||||
- B?C: Added support for Z1RCC
|
||||
- M?R: User Guide enhancements and corrections
|
||||
- D?H: Added support for specification of secondary console
|
||||
- WBW: Added platform for Monsputer
|
||||
- WBW: Added FAT.COM to standard ROM Disk (removed RMAC.COM & LINK.COM)
|
||||
|
||||
Version 3.3
|
||||
-----------
|
||||
NOTE: v3.3 was never released
|
||||
- WBW: Support Front Panel switches
|
||||
- A?C: Preliminary support for Z80-Retro
|
||||
- A?C: Support for SD PIO
|
||||
- A?C: Support for Z80-Retro SD interface
|
||||
- WBW: Support per-drive floppy configuration
|
||||
- WBW: Support for Bill Shen's VGARC
|
||||
- WBW: Support for MG014 Parallel Port module + printer
|
||||
- WBW: Support for IMM Zip Drive on PPI interface (much inspiration from Alan Cox)
|
||||
- WBW: Support for PPA Zip Drive on PPI interface (much inspiration from Alan Cox)
|
||||
- WBW: Support for SyQuest SparQ Drive on PPI interface (much inspiration from Alan Cox)
|
||||
- WBW: Support for ATAPI Disk Drives (not CD-ROMs) on IDE and PPIDE interfaces
|
||||
- R?P: Added new disk images: Aztec C, MS BASIC Compiler, MS Fortran, Games, HiTech-C, Turbo Pascal, SLR Z80ASM
|
||||
- JBL: Added RCZ80 configuration for ColecoVision
|
||||
- WBW: Support for Z180 running interrupt mode 1
|
||||
- WBW: Preliminary support for S100 Computers Z180
|
||||
- WBW: Preliminary support for Dan Werner's ESP32 MBC Module
|
||||
- WBW: Early support for Duodyne base system (CPU/UART/ROM/RAM/RTC/SPK)
|
||||
- M?C: Fixed XM to allow specifying HBIOS port for send operations
|
||||
- WBW: Fix S100 Z180 LED operation (credit to Jay Cotton for finding this issue)
|
||||
- WBW: QPM system image is now combined with current CBIOS during build
|
||||
- WBW: Added framework for Heath platform
|
||||
- WBW: Support for USB Disks via CH375/CH376
|
||||
- D?J: Support for Raspberry Pi build process
|
||||
|
||||
Version 3.2.1
|
||||
-------------
|
||||
- M?P: Fixed Zeta 2 FDD and CPUSPD config settings
|
||||
- WBW: Fixed SURVEY.COM (again)
|
||||
- DDW: Updates to DOS/65 binaries in disk images
|
||||
- PMS: Updates to VGMPLAY including support for YM2151
|
||||
- WBW: Fix for quark delay adjustment being trashed
|
||||
|
||||
Version 3.2
|
||||
-----------
|
||||
- WBW: Version bump for release
|
||||
|
||||
Version 3.1.1
|
||||
-------------
|
||||
- WBW: Version bumped due to pervasive changes
|
||||
- WBW: Preliminary hard disk partition support (backward compatible)
|
||||
- WBW: Change Propeller VGA signal timings to 60Hz refresh
|
||||
- WBW: Enhanced SYSTEM RESET function to allow a warm start back to boot loader
|
||||
- C?O: Add DUART driver
|
||||
- WBW: Early Z280 support (requires 512K RAM/ROM board)
|
||||
- HCS: ZRC memory manager support
|
||||
- S?K: Support for Tiny Z80 by Sergey
|
||||
- E?B: Support for v6 YM/AY sound card
|
||||
- C?M: Support for RCBus bus PropIO V2
|
||||
- W?S: Updated FLASH software to v1.3.4
|
||||
- PMS: Preliminary support for writing to FLASH ROMs
|
||||
- PMS: Creation of process to update ROM system area w/o updating ROM disk contents
|
||||
- PMS: Added "updater.asm" which allows uploading and updating ROM in one step
|
||||
- WBW: Support for Z280 w/ native memory and interrupt mode 3
|
||||
- WBW: Support for Z280 UART (interrupt driven only in interrupt mode 3)
|
||||
- WBW: Add support Z80-512K (watchdog and LED)
|
||||
- WBW: Add support for ZZ80MB address map
|
||||
- PLS: Add support for Z180 invalid opcode trap
|
||||
- WBW: Add support for ZZRCC
|
||||
- WBW: Allow selection of RAM/ROM disk individually in build
|
||||
- WBW: Support 256KB ROM size
|
||||
- WBW: CP/M 3 RTC support is now complete (reads and writes RTC date/time)
|
||||
- WBW: Add config to allow swapping logical order of MT011 SPI ports
|
||||
- WBW: COPY.COM updated from v1.72 -> v1.73 throughout distribution
|
||||
- D?M: CP/NET for CP/M 2.2 and CP/M 3 (requires MT011)
|
||||
- D?M: SD driver fixes for MT011
|
||||
- J?C: Added FIND application from Jay Cotton
|
||||
- PMS: Preliminary support for I2C-based DS1307 clock
|
||||
- WBW: FD driver auto hardware detect (thanks Alan Cox)
|
||||
- D?N: Added support for TMS V9958 VDU
|
||||
- D?N: Added support for MSX keyboard
|
||||
- D?N: Added support for RP5C01 RTC
|
||||
- L?N: Slightly enhanced ZCPRD&J w/ a couple bug fixes
|
||||
- L?N: UNZIPZ4 which handles most modern ZIP file compression algorithms
|
||||
- AJL: Preliminary support for MBC systems
|
||||
- WBW: Added preliminary support for DSKYng
|
||||
- WBW: Elevated MBC to a platform
|
||||
- WBW: Added support for MBC user LEDs
|
||||
- PMS: Early DMA support
|
||||
- W?S: Updated FLASH software to v1.3.5 (supports 128KB A29010B, 512KB A29040B)
|
||||
- DDW: Support for DSKYng capabitlities
|
||||
- WBW: Added Phil Summers' ROM Updater into ROM Loader
|
||||
- AJL: Added ramtest app (requires SBC and MBC for now)
|
||||
- L?N: Provided SCOPY, XSUB01, and EX applications
|
||||
- WBW: Added support for MBC FDC to FDU application
|
||||
- WBW: Added support for MBC FDC to HBIOS
|
||||
- WBW: Refactored make process
|
||||
- WBW: Added ROM verification to boot process
|
||||
- WBW: Added Z80 instruction test apps to user area 5 in CP/M & ZSDOS
|
||||
- WBW: Add support for LINC sound card
|
||||
- WBW: Add interrupt receive support to UART driver
|
||||
- PMS: Add XModem transfer within Debug Monitor
|
||||
- PMS & AJL: Add DMAMON test application
|
||||
- PMS: Add ZMP adaptation
|
||||
- LWN: Substantial BPBIOS cleanup
|
||||
- AJL: Add ZMD adaptation
|
||||
- D?T: Substantial update to TastyBasic incuding a .COM executable
|
||||
- PMS: Added VGM audio file player
|
||||
- WBW: ZPMLDR and ZPM3 fixes, credit to Lars Nelson for finding ZPM3 source!
|
||||
- DDW: Add support for MBC sound card
|
||||
- WBW: Add support for "romless" booting
|
||||
- L?N: Fixes for ZCPR-D&J (buffer overflow, default drive/user)
|
||||
- J?P: Add support for DS1501 RTC
|
||||
- LLS: Added a user defined mode for SD Card interfaces (not complete)
|
||||
- L?N: Updated ZDE to v1.8 including time stamp preservation fixes
|
||||
- D?M: Minor update to CP/NET client files, fix to CPNBOOT
|
||||
- WBW: Added p-System IV.0 Z80 implementation
|
||||
- WBW: Hacked SURVEY to work around bank switching crash
|
||||
|
||||
Version 3.1
|
||||
-----------
|
||||
- WBW: Refactored ROM Loader
|
||||
- WBW: INTRTC periodic timer based clock
|
||||
- WBW: FDISK80 updated to allow reserving up to 256 slices
|
||||
- WBW: Added support dual 16C550 UART on RCBus platform
|
||||
- WBW: Made .com images smaller (contain only Z-System now)
|
||||
- WBW: Support automatic clock hardware detection and fallback
|
||||
- WBW: Support use of CTC for SIO baud rate divisors
|
||||
- WBW: Updated IDE and PPIDE drivers to improve old CF Card compatibility
|
||||
- WBW: Support TIMER mode in CTC driver
|
||||
- DEN: Added sound driver support
|
||||
- DEN: Added SN76489 sound chip driver
|
||||
- M?O: RomWBW Disk Catalog document
|
||||
- DEN: Updated TMS to optionally trigger SYSTIMER interrupt (TMSTIMENABLE)
|
||||
- J?M: Updated KERMIT applications with VT100 terminal support
|
||||
- A?C: Added support for EPFDC
|
||||
- PMS: Added AY driver with new sound API support
|
||||
- DEN: Allow immediate autoboot startup
|
||||
- DEN: Support for floppy device count parameter
|
||||
|
||||
Version 3.0.1
|
||||
-------------
|
||||
- WBW: Increase XModem timeout waiting for host to start sending
|
||||
- WBW: Update TMS driver to dynamically increase Z180 I/O W/S inside driver
|
||||
- MJS: Update CLRDIR for CP/M 3 compatibility
|
||||
- WBW: Corrected cursor on/off esc sequence in pre-configured ZDE
|
||||
- WBW: Fix automatic CRT console switching under CP/M 3 and ZPM3
|
||||
- WBW: DSRTC driver now correctly returns an error if there is no RTC present
|
||||
|
||||
Version 3.0.0
|
||||
-------------
|
||||
- WBW: v2.9.2 -> 3.0 version upgrade due to scope of changes
|
||||
|
||||
Version 2.9.2
|
||||
-------------
|
||||
- PMS: Fixed DS1210-related issue resulting in "Invalid BIOS" errors
|
||||
- SCC: Support for SC126 motherboard
|
||||
- WBW: Enable Auto-CTS/DCD in SIO driver for pacing output data
|
||||
- WBW: Support missing pull-up resistors on SPI SD adapter boards (common)
|
||||
- WBW: Support two SIO modules w/ auto-detection
|
||||
- PMS: Support ECB USB-FIFO board
|
||||
- WBW: Fixed ASSIGN issue with incorrect DPB selection
|
||||
- WBW: Add RCBus Z180 AY sound support to TUNE app
|
||||
- WBW: Add RCBus AY sound support to AY driver
|
||||
- WBW: Add SC126 platform
|
||||
- WBW: Config files cleanup
|
||||
- WBW: Add interrupt support to ASCI driver
|
||||
- WBW: Refactored XModem overlay, merged USB-FIFO support
|
||||
- PMS: Added DS1210 low battery detection/message
|
||||
- PMS: Added note playing ability to SPK driver
|
||||
- WBW: Support disk I/O to any memory bank
|
||||
- WBW: Fix floppy I/O error on slow CPUs w/ ints active (credit Jorge Rodrigues)
|
||||
- WBW: Support for KIO chip (based on board by Tom Szolyga)
|
||||
- N?B: Made ZCAL Y2K compliant
|
||||
- WBW: Show disk activity on diagnostic LEDs
|
||||
- WBW: DSRTC now detects DS-1302 presence dynamically
|
||||
- WBW: SC126 platform renamed to SCZ180 w/ configs for SC126, SC130
|
||||
- WBW: Add status LED support
|
||||
- WBW: Add support for secondry SPI (SD Card) on SC126
|
||||
- PMS: Add sound support to NASCOM BASIC
|
||||
- WBW: Updated FAT to add MD and FORMAT commands
|
||||
- WBW: Add CP/M 3 (experimental)
|
||||
- M?T: Support Shift register SPI WIZNET for RCBus
|
||||
- PLS: Added seconds register in HBIOS
|
||||
- WBW: More flexible table-driven config in TUNE.COM
|
||||
- PMS: Added timer support for Zilog Peripherals ECB Board
|
||||
- PLS: Enhanced Intel Hex Load in dbgmon
|
||||
- WBW: Overhaul disk image creation
|
||||
- WBW: Added support for Dyno platform (based on work by Steve Garcia)
|
||||
- SLG: Added support for BQ4845 RTC (bqrtc.asm)
|
||||
- PMS: Added 80x30 video mode to VGA3 driver
|
||||
- PMS: Added 80x43 video mode
|
||||
- PMS: Added font compression option
|
||||
- PMS: Added a "safe mode" startup w/ minimal device support
|
||||
- WBW: Switch RC/SC Z180 platforms to 115,200 default baud rate
|
||||
- PMS: Enhanced PPIDE driver to handle multiple PPI interfaces
|
||||
- PMS: Added a ROM based game
|
||||
- WBW: Only assign drive letters to hard disk devices with media
|
||||
- WBW: Enhanced IDE driver to handle multiple IDE interfaces
|
||||
- D?R: Contributed SC126 How-To: Preparing a MicroSD Card to Transfer Files to/from a Linux System
|
||||
- PMS: Updated romldr to handle more than 9 drives
|
||||
- PMS: Added "user" rom module template
|
||||
- PMS: Added CP/M 3 manuals
|
||||
- WBW: Boot from any slice
|
||||
- C?M: Added Unix build process
|
||||
- PLS: FreeRTOS compatibility
|
||||
- WWB: Removed OSLDR application (can't handle new OSes)
|
||||
|
||||
Version 2.9.1
|
||||
-------------
|
||||
- E?B: Added support for RCBus RTC
|
||||
- WBW: Converted PTXPLAY to TUNE (now plays PT2/PT3/MYM sounds files)
|
||||
- WBW: Updated Win32DiskImager to v1.0
|
||||
- WBW: Implemented character attributes on Propeller based consoles
|
||||
- MS: Added support for BEL function in Propeller based consoles
|
||||
- WBW: Support additional escape sequences in Propeller console ANSI emulation
|
||||
- WBW: Map LPT: to second serial port, UL1: to third serial port
|
||||
- WBW: Update default IOBYTE so that LST:=LPT: by default
|
||||
- WBW: Fixed missing drive/head setup for writes in PPIDE
|
||||
- WBW: Fixed XModem HBIOS console driver for file send operations
|
||||
- WBW: Preliminary support for RC180 platform (Z180 module in RCBus)
|
||||
- WBW: Added NZCOM distribution files to third slice of hard disk image
|
||||
- WBW: Fixed getnum32 bug in MODE command (found by Phil Summers)
|
||||
- PMS: Added serial support for Zilog Peripherals Baord
|
||||
- WBW: Added preliminary support for interrupt management API
|
||||
- PMS: Improved boot messages in RAM-Floppy driver
|
||||
- PMS: Added charge setting display to RTC boot messages
|
||||
- WBW: Add SmallZ80 support to FDU
|
||||
- WBW: Refactored Debug Monitor w/ improved syntax parsing and help
|
||||
- PMS: Added Forth, Nascom BASIC, and Tasty BASIC to ROM
|
||||
- PMS: Refactored ROM Loader to support more ROM images, now table driven
|
||||
- WBW: Refactored DSKY code
|
||||
- S?K: Initial support for Easy Z80
|
||||
- PMS: Enhance VDU driver to support alternative screen dimensions
|
||||
- WBW: DDT and DDTZ modified to use RST 30 instead of RST 38 to avoid conflicts with IM 1 interrupts
|
||||
- WBW: Added timer interrupt support for CTC under Zeta 2 and Easy Z80
|
||||
- WBW: Support LBA style access in floppy driver
|
||||
- WBW: Added beta version of FAT filesystem utility (copy, dir, del, ren)
|
||||
- SCC: Added support for native memory addressing on Z180-based RCBus
|
||||
- PMS: Dynamically discover and display processor type at boot
|
||||
- J?L: Added German keyboard support to PPK and KBD drivers
|
||||
|
||||
Version 2.9.0
|
||||
-------------
|
||||
- WBW: Implemented multi-sector I/O in all disk drivers
|
||||
- WBW: Added support for RCBus SMB Floppy controller modules (SMC and WDC)
|
||||
- WBW: New function dispatching for character/disk/video drivers
|
||||
- WBW: Updated FDU app to support RCBus floppy controllers
|
||||
- WBW: Added TIMER app to display system timer value
|
||||
- WBW: Refactored interrupt management code
|
||||
- WBW: Added PTXPLAY application and sample tunes
|
||||
|
||||
Version 2.8.6
|
||||
-------------
|
||||
- WBW: Added support for RCBus (SIO and ACIA drivers primarily)
|
||||
- WBW: Automatically detect and run PROFILE.SUB on boot drive if it exists
|
||||
- WBW: Fixed Dual SD Board detection
|
||||
- WBW: Added console support to XModem (for RCBus primarily)
|
||||
- E?B: Fixed IDE/PPIDE when used with non-CF drives
|
||||
- WBW: Patched SUBMIT.COM so that it always puts temp file on A: for immediate execution
|
||||
- WBW: Accommodate spin up time for true IDE hard disks (IDE or PPIDE)
|
||||
|
||||
Version 2.8.5
|
||||
-------------
|
||||
- WBW: Cleaned up support in TMS driver for SCG board
|
||||
|
||||
Version 2.8.4
|
||||
-------------
|
||||
- WBW: FD.COM renamed to FDU.COM and integrated with build
|
||||
- WBW: FDU.COM enhanced to select FDC hardare at startup to
|
||||
eliminate multiple versions.
|
||||
|
||||
Version 2.8.3
|
||||
-------------
|
||||
- WBW: Added MODE command
|
||||
- WBW: Removed obsolete 1200.COM, 9600.COM, and 38400.COM
|
||||
- WBW: New XM.COM that automatically adapts to primary port of platform
|
||||
- WBW: XM.COM now handles 38400 baud at 4MHz
|
||||
- WBW: Removed obsolete XM versions: XM5.COM, XM-A0.COM, XM-A1.COM
|
||||
|
||||
Version 2.8.2
|
||||
-------------
|
||||
- WBW: Adjusted VGA3 register setup per John's recommendations
|
||||
|
||||
Version 2.8.1
|
||||
-------------
|
||||
- WBW: Fix FDISK80
|
||||
- WBW: Upgrade to latest production UNA 2.1-45
|
||||
|
||||
Version 2.8.0
|
||||
-------------
|
||||
- WBW: Add support for VGA3 board
|
||||
|
||||
Version 2.7.1
|
||||
-------------
|
||||
- WBW: Replace ZX with XP compatible build (no functional changes)
|
||||
- WBW: Reset BDOS serial number on warm start
|
||||
- WBW: Turn off DRAM refresh on Z180 (fixes Z180 CPU speed detection)
|
||||
|
||||
Version 2.7.0
|
||||
-------------
|
||||
- WBW: Memory page reorganization
|
||||
- WBW: Support for Zeta 2 (from Sergey Kiselev)
|
||||
- WBW: Support loading from image file (UNA FSFAT)
|
||||
- WBW: Dynamic CPU speed detection
|
||||
|
||||
Version 2.6.5
|
||||
-------------
|
||||
- WBW: Yet more DS1302 clock driver delay mods
|
||||
|
||||
Version 2.6.4
|
||||
-------------
|
||||
- WBW: Yet more DS1302 clock driver delay mods
|
||||
|
||||
Version 2.6.3
|
||||
-------------
|
||||
- WBW: DS1302 clock driver modified to observe proper delays
|
||||
|
||||
Version 2.6.2
|
||||
-------------
|
||||
- WBW: ASSIGN.COM substantially improved to map all drive types
|
||||
|
||||
Version 2.6.1
|
||||
-------------
|
||||
- WBW: Both CP/M and ZSystem are imbedded in the ROM
|
||||
image.
|
||||
|
||||
Version 2.6
|
||||
-----------
|
||||
- WBW: Old Apps removed (MULTIFMT, CPMNAME, SETLABEL, etc.)
|
||||
@@ -81,7 +545,7 @@ Version 2.0
|
||||
- DWG: Entire new suite of Apps written in Aztec C
|
||||
- DWG: BANKER.COM - displays bank identification and version information
|
||||
- DWG: CPMNAME.COM - displays CBIOS header data and SYSCFG data, names and vaues
|
||||
- DWG: CHARS.COM - displays ascii map as reference
|
||||
- DWG: CHARS.COM - displays ascii map as reference
|
||||
- DWG: CLS.COM - clears screen
|
||||
- DWG: LABEL.COM - displays and changes drive labels for drives with reserved tracks
|
||||
- DWG: MAP.COM - like old map command, displays drives and logical unit labels and changes LU values
|
||||
@@ -113,7 +577,7 @@ Version 1.5.1
|
||||
- WBW: Added ZSDOS clock drivers (see Support\Clock)
|
||||
- WBW: Overhaul of ZSystem ROM Disk (see Doc\ZSystem.txt)
|
||||
- WBW: Update PropIO ANSI emulation for compatiblity with ASSIGN
|
||||
- DWG: Added version tags to all applications, and IDENT program to
|
||||
- DWG: Added version tags to all applications, and IDENT program to
|
||||
check version of utilities.
|
||||
- DWG: Added MULTIFMT program which prepares new media for use by
|
||||
initializing the metadata and clearing the directory sectors of
|
||||
@@ -123,8 +587,8 @@ Version 1.5.1
|
||||
- DWG: ANALYSE and HELLO programs removed from ROM due space concerns
|
||||
- DWG: Additional macro librarties added supporting program identification
|
||||
(IDENTITY.LIB/ASM) and access to drive metadata (METADATA.LIB/ASM),
|
||||
and realtime selection of logical units from within new application
|
||||
programs (LOGICALS.LIB/ASM).
|
||||
and realtime selection of logical units from within new application
|
||||
programs (LOGICALS.LIB/ASM).
|
||||
- DWG: Added TERM_VT52 for VDU compatbility, all apps now compliant
|
||||
- DGG: Contributed Linux build (see Doc\BuildLinux.txt)
|
||||
|
||||
@@ -152,7 +616,7 @@ Version 1.4
|
||||
- DWG: Add various .SUB files used for application maintenance
|
||||
- DWG: Enhanced utility building .SUB files to only contain libs utilitized
|
||||
- DWG: Add BUILD.SUB to build all applications and DEVFILES.LBR
|
||||
- DWG: Add/update RMAC macro libraries used in Apps -
|
||||
- DWG: Add/update RMAC macro libraries used in Apps -
|
||||
- DWG: BIOSHDR, STDLIB, STRCPY, STRLEN, CPMBIOS, CPMBDOS, TERMINAL, HARDWARE,
|
||||
- DWG: CPMAPPL, GLOBALS, ATOI, LUBIND, APPLVERS, MEMORY(memcpy,memset), PORTAB
|
||||
- DWG: Add/Repair BIOS support for Boot Drive login during CP/M Coldstart
|
||||
@@ -171,7 +635,7 @@ Version 1.4
|
||||
- DWG: Add LABEL utility to insert label into drive/slice metadata
|
||||
- DWG: Add 16 char label field to metadata
|
||||
- DWG: ASSIGN utility displays and manipulates DPH/DPB & logical unit parameters
|
||||
- DWG/WBW: Collaborated on design of Logical Unit DPH enhancemnt
|
||||
- DWG/WBW: Collaborated on design of Logical Unit DPH enhancemnt
|
||||
- WBW: Proposed MAP utility functionality
|
||||
- WBW: Implement slice selection API for DSK devices
|
||||
- WBW: Record boot drive in config memory at load time
|
||||
@@ -309,4 +773,4 @@ interrupts disabled the BIOS will now start OK even if some vagrant
|
||||
hardware is asserting an interrupt (DISKIO). Seems like this is better
|
||||
anyway -- general idea is that we only enable interupts precisely
|
||||
when desired for very specific controled purposes since there is no
|
||||
concept of interrupt dispatching available.
|
||||
concept of interrupt dispatching available.
|
||||
|
||||
BIN
Doc/Contrib/AY-3-8910 Registers.xlsx
Normal file
BIN
Doc/Contrib/AY-3-8910 Registers.xlsx
Normal file
Binary file not shown.
BIN
Doc/Contrib/DSKY.pdf
Normal file
BIN
Doc/Contrib/DSKY.pdf
Normal file
Binary file not shown.
BIN
Doc/Contrib/How to Make Disk Images in Linux with DD Command.pdf
Normal file
BIN
Doc/Contrib/How to Make Disk Images in Linux with DD Command.pdf
Normal file
Binary file not shown.
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user