Compare commits
6300 Commits
unlabeled-
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
02870802f0 | ||
|
|
c8ebe9995a | ||
|
|
d17d9e31a7 | ||
|
|
456d52f59f | ||
|
|
c40034452e | ||
|
|
f1cdb32025 | ||
|
|
2dbbacfad9 | ||
|
|
e87791b38a | ||
|
|
a44e18bb1e | ||
|
|
c56e850eca | ||
|
|
eff81b4687 | ||
|
|
0f8745dc8d | ||
|
|
ab55ecefee | ||
|
|
f07a93357c | ||
|
|
b9c194b210 | ||
|
|
ff34b6bce7 | ||
|
|
67cda9e22f | ||
|
|
cc4e74077c | ||
|
|
210a4c9ce5 | ||
|
|
16e42da0ed | ||
|
|
4bc87420d1 | ||
|
|
72bc0db96a | ||
|
|
4b494f90e2 | ||
|
|
072e795aa3 | ||
|
|
d0ac75ea66 | ||
|
|
8efccf82c7 | ||
|
|
5e831ec966 | ||
|
|
3310ddcdac | ||
|
|
dc9c6c8ca2 | ||
|
|
ec96baa6dc | ||
|
|
9f641ff005 | ||
|
|
742a6046e7 | ||
|
|
3ef5fe565b | ||
|
|
bbdd256739 | ||
|
|
9236d6e4aa | ||
|
|
8256a10133 | ||
|
|
20f09f610e | ||
|
|
b218202619 | ||
|
|
594fb05c87 | ||
|
|
d06e0b1670 | ||
|
|
debf852e0d | ||
|
|
e9e9c8ac50 | ||
|
|
a45f7db24a | ||
|
|
4c74889bc1 | ||
|
|
1820152008 | ||
|
|
c90ee3021b | ||
|
|
5c12b869aa | ||
|
|
a1c93cbbe6 | ||
|
|
f4e3111f50 | ||
|
|
ac72c550ba | ||
|
|
7e624e2f1d | ||
|
|
65e8bffed3 | ||
|
|
1189d41aec | ||
|
|
d6fc2d19f9 | ||
|
|
c710fde0d5 | ||
|
|
9d8c776888 | ||
|
|
dcaec5dfa8 | ||
|
|
d1cf99c245 | ||
|
|
e02179a9fe | ||
|
|
13496800ab | ||
|
|
15a318b4b1 | ||
|
|
de5dfda220 | ||
|
|
4839ce3ec6 | ||
|
|
5621f951a2 | ||
|
|
116a3f49c9 | ||
|
|
2b16e9f8dc | ||
|
|
87ad9a6852 | ||
|
|
f2cfcba52e | ||
|
|
9731e1e349 | ||
|
|
db4d300c33 | ||
|
|
d48c81664f | ||
|
|
f33fd63590 | ||
|
|
078faadbf9 | ||
|
|
f5d41474da | ||
|
|
0e349f88a6 | ||
|
|
43857acb0b | ||
|
|
3756b414de | ||
|
|
42c2cdb985 | ||
|
|
1a19c3ffec | ||
|
|
cc57ec1e11 | ||
|
|
892a545b10 | ||
|
|
a5c9e8b09c | ||
|
|
fd5b9e1450 | ||
|
|
173ca7d5d7 | ||
|
|
e85ebeeab0 | ||
|
|
002c49ec2b | ||
|
|
583c2df92a | ||
|
|
f07522680d | ||
|
|
913bf332f3 | ||
|
|
2ac12e3015 | ||
|
|
c74f9cc2e9 | ||
|
|
594e84da95 | ||
|
|
5da1922c4f | ||
|
|
c5e7c60c76 | ||
|
|
19df20b027 | ||
|
|
aacc645329 | ||
|
|
b48e18fbd9 | ||
|
|
6a00063b18 | ||
|
|
2b20613b72 | ||
|
|
81b31c3a1c | ||
|
|
99c81620c7 | ||
|
|
2a1b5444b2 | ||
|
|
96db4093b3 | ||
|
|
58ca908043 | ||
|
|
84aabce8f7 | ||
|
|
2ec25a4f86 | ||
|
|
2c98eae913 | ||
|
|
5d7360edf0 | ||
|
|
bb5ab180d3 | ||
|
|
b15186d574 | ||
|
|
9b82e21f06 | ||
|
|
84b35a215a | ||
|
|
d0bff8b01c | ||
|
|
ca3c5d0d0c | ||
|
|
6d72be8b43 | ||
|
|
4aa396fdec | ||
|
|
7ce42ea371 | ||
|
|
0f8115e3c9 | ||
|
|
8be57751c3 | ||
|
|
84e903586b | ||
|
|
d925ad7c46 | ||
|
|
01e7d0c56d | ||
|
|
eba0b5023e | ||
|
|
d228deb16d | ||
|
|
4659f40b18 | ||
|
|
8601c6c5bf | ||
|
|
df67dbcaeb | ||
|
|
696b04e5ae | ||
|
|
322597e715 | ||
|
|
1523514504 | ||
|
|
44daceddd2 | ||
|
|
8bcd8ede76 | ||
|
|
ce6de53e60 | ||
|
|
c308262eb6 | ||
|
|
8348fa5474 | ||
|
|
1ccc853b71 | ||
|
|
4eb2b4351b | ||
|
|
0e5a52c1c9 | ||
|
|
faff5b8361 | ||
|
|
2619a6aeb1 | ||
|
|
f35d231c1f | ||
|
|
46d9eff270 | ||
|
|
38276da8ea | ||
|
|
8364064fae | ||
|
|
98c0efeca4 | ||
|
|
bffe70f9ac | ||
|
|
b48e9d9550 | ||
|
|
d73458fd52 | ||
|
|
b33fd563b7 | ||
|
|
dd760329aa | ||
|
|
383677ff3e | ||
|
|
75d10944b8 | ||
|
|
d6bd2c86bd | ||
|
|
8952648ab5 | ||
|
|
06ed8b1b8f | ||
|
|
6f46578879 | ||
|
|
4a8b62c862 | ||
|
|
1f78b7ff4e | ||
|
|
2d5e79ec0a | ||
|
|
58fad2b368 | ||
|
|
188f135e5e | ||
|
|
62a8851bc8 | ||
|
|
46d504c483 | ||
|
|
9c722420dd | ||
|
|
80b4463439 | ||
|
|
ac7b578128 | ||
|
|
09f4845060 | ||
|
|
47d990fec8 | ||
|
|
f3e9069ea0 | ||
|
|
217062585d | ||
|
|
a9c5aa42fd | ||
|
|
8b292e1a83 | ||
|
|
1465633090 | ||
|
|
0bb9513457 | ||
|
|
4473031ec4 | ||
|
|
721ad3ba6c | ||
|
|
5f529d8ff1 | ||
|
|
bc943a92c2 | ||
|
|
c017d49dae | ||
|
|
e604ef3d4c | ||
|
|
90844c1272 | ||
|
|
8e9303b238 | ||
|
|
aad716cd20 | ||
|
|
fcecc66f2d | ||
|
|
e05bc9c9b0 | ||
|
|
6d37bf15b8 | ||
|
|
b29f55a533 | ||
|
|
62871bb5d7 | ||
|
|
82a585f684 | ||
|
|
af73344cf0 | ||
|
|
2c16cb7244 | ||
|
|
eb1e26bbfa | ||
|
|
78dba844b2 | ||
|
|
5304588eea | ||
|
|
1c73ef8e61 | ||
|
|
1f824aa3e8 | ||
|
|
1e72f2443d | ||
|
|
a173f6a6c0 | ||
|
|
4593af6c11 | ||
|
|
bb2b8fae64 | ||
|
|
7b80cd2db0 | ||
|
|
8a3e083fe1 | ||
|
|
a7939a407b | ||
|
|
b2b88a89e1 | ||
|
|
8ec7e4667c | ||
|
|
b9d98bd0ff | ||
|
|
bce7648b99 | ||
|
|
dd3c45ecf2 | ||
|
|
01314faaac | ||
|
|
9aacafbc5a | ||
|
|
633780d9f0 | ||
|
|
f67d6d1491 | ||
|
|
54ea735407 | ||
|
|
44f229d88a | ||
|
|
fbe65f8a9a | ||
|
|
3ee71dd844 | ||
|
|
a54dcb8e92 | ||
|
|
c8f1fe9511 | ||
|
|
3620781344 | ||
|
|
3f2df9c88d | ||
|
|
84f3a18362 | ||
|
|
3a69ad76f4 | ||
|
|
8769a2b8bc | ||
|
|
8b27bc6170 | ||
|
|
71e0d85a11 | ||
|
|
c5f106f53e | ||
|
|
309f5d5560 | ||
|
|
f6d77b9061 | ||
|
|
be7ec5cdd0 | ||
|
|
22d8b82972 | ||
|
|
84701a5c29 | ||
|
|
b034d8695b | ||
|
|
92c1b4a4c1 | ||
|
|
51000eef76 | ||
|
|
32762aad2b | ||
|
|
963a256f68 | ||
|
|
852a474ee3 | ||
|
|
6da4811e19 | ||
|
|
9c81d2fe39 | ||
|
|
ed1ddc5baa | ||
|
|
bc2672d642 | ||
|
|
0f5ae5305d | ||
|
|
cb09878a1f | ||
|
|
f7d14e649d | ||
|
|
dbc7cd6b19 | ||
|
|
38b87fe902 | ||
|
|
ee83cfcf9b | ||
|
|
e2cf5fbce2 | ||
|
|
5ef43bb829 | ||
|
|
04a887eee9 | ||
|
|
9158d97c6f | ||
|
|
d5cc72efc2 | ||
|
|
65ffc7f057 | ||
|
|
dbf0723fdb | ||
|
|
611e8b03fe | ||
|
|
b2ffedbabd | ||
|
|
06df95dc13 | ||
|
|
902ff02551 | ||
|
|
40db0f2abc | ||
|
|
42f568c0e0 | ||
|
|
9493d1cde9 | ||
|
|
c432c83666 | ||
|
|
fed4e8aba5 | ||
|
|
8f4ec7280c | ||
|
|
6fb0645cd6 | ||
|
|
3db9a605e3 | ||
|
|
8262bfb8f4 | ||
|
|
bf9e4d20d9 | ||
|
|
a2f0e7d65b | ||
|
|
f6f9b3fd82 | ||
|
|
6021fd93ff | ||
|
|
6d5ee0158d | ||
|
|
47c63fb2e8 | ||
|
|
0418600539 | ||
|
|
8b112a5f65 | ||
|
|
6c797e83e3 | ||
|
|
df704932ab | ||
|
|
65282761ed | ||
|
|
30d31515c8 | ||
|
|
dc55bdabcf | ||
|
|
03de17911b | ||
|
|
a60ff7fcea | ||
|
|
81252befc9 | ||
|
|
0406eff439 | ||
|
|
0ed5418bec | ||
|
|
8ffc86d8ec | ||
|
|
793e393bb0 | ||
|
|
92033f240c | ||
|
|
03ce92b072 | ||
|
|
87c475ff69 | ||
|
|
06f158f980 | ||
|
|
044f3c9814 | ||
|
|
dc65347504 | ||
|
|
b4bda72e7f | ||
|
|
fd2a479d52 | ||
|
|
55f1a0f8e8 | ||
|
|
0f128c0bed | ||
|
|
08b6918ed8 | ||
|
|
9a0c40a6b5 | ||
|
|
1253529533 | ||
|
|
f2d5520159 | ||
|
|
aac653056b | ||
|
|
bbdf73b85a | ||
|
|
d516ce7b75 | ||
|
|
ed95a6c170 | ||
|
|
6e1aa1564b | ||
|
|
ec4cf10bbf | ||
|
|
d99dfe6e0c | ||
|
|
339c8f06be | ||
|
|
5fd4671c8b | ||
|
|
c629ab32f9 | ||
|
|
26edba4590 | ||
|
|
5289b6985e | ||
|
|
2d7f92d93a | ||
|
|
f4b9fd5b56 | ||
|
|
e3ec5a31d6 | ||
|
|
0fbae249cc | ||
|
|
e9bedfcbd2 | ||
|
|
d92f198d58 | ||
|
|
ba76ac9fed | ||
|
|
61e0f01e71 | ||
|
|
ca09a9b0e8 | ||
|
|
42b693b1af | ||
|
|
989015a051 | ||
|
|
a240c8014c | ||
|
|
9ed6b40a86 | ||
|
|
6bb01f61b7 | ||
|
|
7a927fe2da | ||
|
|
121acff9d8 | ||
|
|
624bb4e0d9 | ||
|
|
71aea9f012 | ||
|
|
c62de7632a | ||
|
|
cd31b4fce6 | ||
|
|
ede92325cc | ||
|
|
32f4c842ba | ||
|
|
ca79ae568d | ||
|
|
21d49ffece | ||
|
|
3046c82d45 | ||
|
|
efa0bfa27d | ||
|
|
5bfeacc519 | ||
|
|
b8dbfe39cb | ||
|
|
48fe3a11bf | ||
|
|
fc5a840f24 | ||
|
|
e3d9a68078 | ||
|
|
25a03c14a5 | ||
|
|
ad5b127ae9 | ||
|
|
bf2357624d | ||
|
|
07586a0fdd | ||
|
|
86412ca30d | ||
|
|
86218a5f3d | ||
|
|
81453a1f7f | ||
|
|
25cd851c6e | ||
|
|
44dd8a38e6 | ||
|
|
0180e9da44 | ||
|
|
6f0543c1a3 | ||
|
|
6ecb9f3d76 | ||
|
|
0103de87a4 | ||
|
|
1e3cd3ce83 | ||
|
|
7efd46f437 | ||
|
|
5d7b88affb | ||
|
|
16856562c6 | ||
|
|
bfed0ed0ea | ||
|
|
f205e09b97 | ||
|
|
3cfb4fd0e9 | ||
|
|
8490348a28 | ||
|
|
fdc6328400 | ||
|
|
3531d6e107 | ||
|
|
1da92a1e0d | ||
|
|
874ec87fce | ||
|
|
94d63a8d57 | ||
|
|
3ef8ae0b65 | ||
|
|
b16b1c714e | ||
|
|
3a1dc8fd59 | ||
|
|
661464ed0f | ||
|
|
be42195a77 | ||
|
|
1a85dc252e | ||
|
|
74aa5c6e0c | ||
|
|
35d142194c | ||
|
|
a414a9c9c1 | ||
|
|
0a972cd644 | ||
|
|
d66053e2f7 | ||
|
|
3c6c7aa1d7 | ||
|
|
4e11ffc3ac | ||
|
|
9c8a8e6083 | ||
|
|
fe357ec048 | ||
|
|
66d018dc88 | ||
|
|
6236e7f42e | ||
|
|
df52f04600 | ||
|
|
d828522f35 | ||
|
|
decc4ce807 | ||
|
|
6871c56487 | ||
|
|
1aaab3dd69 | ||
|
|
94fde85384 | ||
|
|
d3bb7c1f56 | ||
|
|
218c8c209f | ||
|
|
24a3714754 | ||
|
|
61f4cce396 | ||
|
|
b8d8e1082d | ||
|
|
0261e7a853 | ||
|
|
ef217e26bc | ||
|
|
21e30ab7f7 | ||
|
|
806a084be5 | ||
|
|
b1479c63dc | ||
|
|
90e4d5c15d | ||
|
|
78e493ac0b | ||
|
|
92bee588be | ||
|
|
b77cd9bb8e | ||
|
|
ddef45be2f | ||
|
|
0793b2ecc6 | ||
|
|
56505254c5 | ||
|
|
c89cabee0b | ||
|
|
f29489f3ad | ||
|
|
c21f5558ba | ||
|
|
3628b8b8c0 | ||
|
|
c57d76db57 | ||
|
|
f26dd7bb01 | ||
|
|
bcc84a94d5 | ||
|
|
e97e8edd13 | ||
|
|
5e57b9a901 | ||
|
|
24741f9c69 | ||
|
|
fdfe4f12c0 | ||
|
|
7894646cff | ||
|
|
b0ea434716 | ||
|
|
e960c8cba3 | ||
|
|
25b0941b80 | ||
|
|
550ad0d82c | ||
|
|
9c6968d42c | ||
|
|
58c76078a7 | ||
|
|
83f8bc669c | ||
|
|
6bc329e77c | ||
|
|
0faa8fb27f | ||
|
|
a1f0020de5 | ||
|
|
ebdcf062ec | ||
|
|
f1847c8a28 | ||
|
|
c5fac7eb3b | ||
|
|
f2e8b724db | ||
|
|
d06bb6af86 | ||
|
|
d9df8a922c | ||
|
|
62e3431f8d | ||
|
|
038afe488d | ||
|
|
d8e9515218 | ||
|
|
d12b7be5d1 | ||
|
|
5e72837e62 | ||
|
|
18c50f6768 | ||
|
|
1331833c68 | ||
|
|
be00d7e3f9 | ||
|
|
61501029f9 | ||
|
|
610bb4a6d8 | ||
|
|
e6e41b924f | ||
|
|
eabced42ae | ||
|
|
3c91208f8c | ||
|
|
69ed537f4c | ||
|
|
e101155c40 | ||
|
|
a93d33c53b | ||
|
|
032e0e36d7 | ||
|
|
3dabb8327c | ||
|
|
0fa5010335 | ||
|
|
884b36cfdc | ||
|
|
c14352585a | ||
|
|
0e2665ca35 | ||
|
|
1b4c0de360 | ||
|
|
5093b2f32e | ||
|
|
a62ccfddbb | ||
|
|
3428f93f80 | ||
|
|
e977f41f16 | ||
|
|
abc8061d75 | ||
|
|
abc232fee7 | ||
|
|
f6961821b9 | ||
|
|
a479850890 | ||
|
|
a111adf573 | ||
|
|
1dba0d4628 | ||
|
|
6422389e88 | ||
|
|
56177b33f4 | ||
|
|
acc3f843fe | ||
|
|
ebef128e09 | ||
|
|
9bc6c9ef36 | ||
|
|
13dc306413 | ||
|
|
597c9a97bc | ||
|
|
29b989a53c | ||
|
|
4f932bc6ea | ||
|
|
07c8cac6e5 | ||
|
|
486b73c9ad | ||
|
|
f830152ba8 | ||
|
|
2d22258dd7 | ||
|
|
b4e86b6450 | ||
|
|
6ac18892c8 | ||
|
|
ffb607942e | ||
|
|
a81544287a | ||
|
|
47ad02f4d2 | ||
|
|
eb15533ec8 | ||
|
|
c94e95c158 | ||
|
|
371240c8b9 | ||
|
|
52fd06595a | ||
|
|
a4f651cbee | ||
|
|
ea4b3dc8be | ||
|
|
2da8f052f9 | ||
|
|
03387e093f | ||
|
|
21a720c65d | ||
|
|
48c195edaf | ||
|
|
2f5a5cd1d2 | ||
|
|
6d439c8305 | ||
|
|
5cdd5193e0 | ||
|
|
b751882510 | ||
|
|
bc4aac7ee6 | ||
|
|
9a7b9d316e | ||
|
|
799481ef90 | ||
|
|
e3f7597cde | ||
|
|
744b080599 | ||
|
|
d28c22adf4 | ||
|
|
80982665a3 | ||
|
|
f3fd5ba24b | ||
|
|
8c92c04936 | ||
|
|
4b6c6de71f | ||
|
|
48a8bc1bd1 | ||
|
|
671d9649e9 | ||
|
|
2fde99447d | ||
|
|
9f9e12cbb5 | ||
|
|
261f9a9625 | ||
|
|
e1956258b7 | ||
|
|
2cb7e28100 | ||
|
|
ba200115c8 | ||
|
|
b0e19f7f80 | ||
|
|
267112ad42 | ||
|
|
a49bae8e7f | ||
|
|
144e3edfb2 | ||
|
|
c0a8a2c36f | ||
|
|
adf94d48e8 | ||
|
|
cd1ab39040 | ||
|
|
98a44919ed | ||
|
|
05107a98c9 | ||
|
|
bbb110a15a | ||
|
|
083f358378 | ||
|
|
bc67008f0d | ||
|
|
c44cb846f0 | ||
|
|
e95cc619ee | ||
|
|
ee4d7610f9 | ||
|
|
5ac4321a7a | ||
|
|
638c2fe15e | ||
|
|
1a04e108d4 | ||
|
|
7b5fe8b311 | ||
|
|
238c7717e9 | ||
|
|
e38adbdb89 | ||
|
|
c95f4d2609 | ||
|
|
2a64289208 | ||
|
|
1052c78c59 | ||
|
|
6f0cf8ae19 | ||
|
|
eb2b8d6f04 | ||
|
|
cdae684cd6 | ||
|
|
bafc37f8d0 | ||
|
|
112ab34ab9 | ||
|
|
c1aef17cc8 | ||
|
|
215c3b07b0 | ||
|
|
1ded03a114 | ||
|
|
d0dabdc6b2 | ||
|
|
c9e891733f | ||
|
|
014fa34d31 | ||
|
|
e1cbe380fb | ||
|
|
7ba293d0d6 | ||
|
|
af50f645c0 | ||
|
|
2401d9876c | ||
|
|
dca16dfd0f | ||
|
|
b1c1dec355 | ||
|
|
395e8d4605 | ||
|
|
304bfbade3 | ||
|
|
c8910826b5 | ||
|
|
0bd295c1c0 | ||
|
|
f350a6f701 | ||
|
|
8fd67c5e30 | ||
|
|
e939ab6db0 | ||
|
|
42b5a324eb | ||
|
|
467484a30b | ||
|
|
5c8b465a4e | ||
|
|
e5b7e10f99 | ||
|
|
458946e791 | ||
|
|
7e453d7aa2 | ||
|
|
89ebd7aa4b | ||
|
|
aed8cc5cb6 | ||
|
|
561b7fcf65 | ||
|
|
0c8ce4c9dd | ||
|
|
99d14de3f4 | ||
|
|
61c1a76870 | ||
|
|
e06f0fdfe4 | ||
|
|
82871ed9ab | ||
|
|
a8fe176c06 | ||
|
|
8ab04269c7 | ||
|
|
f6e1e8c000 | ||
|
|
28d8a4af4a | ||
|
|
9f6cc101c8 | ||
|
|
1fca8fde3d | ||
|
|
5e2915512f | ||
|
|
a9cdc723c7 | ||
|
|
3e60fd70c1 | ||
|
|
a2cb61e0f0 | ||
|
|
a2bf695f83 | ||
|
|
2e469361ec | ||
|
|
3d2e5447e6 | ||
|
|
7d8bf4efe8 | ||
|
|
ac7f45b546 | ||
|
|
ff895004b2 | ||
|
|
0b9361b642 | ||
|
|
200b54f28a | ||
|
|
8bca78cd29 | ||
|
|
108f8aacfa | ||
|
|
122a7ab1bb | ||
|
|
b2ea48418a | ||
|
|
057500f1f6 | ||
|
|
f80730fd47 | ||
|
|
f1232235ac | ||
|
|
85fd09415b | ||
|
|
3d9aebdd69 | ||
|
|
c79e53c02e | ||
|
|
551396bc5b | ||
|
|
d858cd7e1b | ||
|
|
9fe21d6e8d | ||
|
|
42edc1d202 | ||
|
|
8023799213 | ||
|
|
31a4b8a26f | ||
|
|
4aa3ae80c8 | ||
|
|
f2fc6667ac | ||
|
|
479d3c1417 | ||
|
|
b0b49e1ab1 | ||
|
|
1b41a02527 | ||
|
|
5150d9cbb2 | ||
|
|
a7dca96e97 | ||
|
|
a96b52e85d | ||
|
|
77fdce183a | ||
|
|
5ad7b5b5ab | ||
|
|
20fec3c6a2 | ||
|
|
6056bb80c1 | ||
|
|
e56e7c50c2 | ||
|
|
0a6915c243 | ||
|
|
f3c71e7d18 | ||
|
|
448c743214 | ||
|
|
4a067ba156 | ||
|
|
e1ae5f02dc | ||
|
|
c5cfce7324 | ||
|
|
3003070e62 | ||
|
|
01e6c10d77 | ||
|
|
a2b39689d1 | ||
|
|
c9b63eaf8d | ||
|
|
6b14e7be46 | ||
|
|
b0da651a21 | ||
|
|
8c801ca268 | ||
|
|
d687237b30 | ||
|
|
8f98fac873 | ||
|
|
b46b9ce380 | ||
|
|
dbf212f30a | ||
|
|
6b7fcb5a8c | ||
|
|
d313baf4f4 | ||
|
|
81e56858c1 | ||
|
|
42d4bff6fb | ||
|
|
fe2e66b273 | ||
|
|
6fb7d510e6 | ||
|
|
85b0f49946 | ||
|
|
8f0c681a67 | ||
|
|
f0253d1dd7 | ||
|
|
b585c03728 | ||
|
|
d4b2adb2dd | ||
|
|
ae57d22fc9 | ||
|
|
ae9ad8fe54 | ||
|
|
5e30d43097 | ||
|
|
bc82da7db8 | ||
|
|
345e8e84dc | ||
|
|
f97cf85423 | ||
|
|
17c450c3cb | ||
|
|
a08ccc7191 | ||
|
|
fd8beaadfa | ||
|
|
0491d8bb32 | ||
|
|
43717e8aa7 | ||
|
|
82de44d5f0 | ||
|
|
66756122bd | ||
|
|
01bc62c104 | ||
|
|
c215fb6510 | ||
|
|
5a89770759 | ||
|
|
5eabd4725b | ||
|
|
d9515cda2c | ||
|
|
0d0e12f563 | ||
|
|
f3ceea65f0 | ||
|
|
a9cd7ac30d | ||
|
|
2b2f52c36b | ||
|
|
add3dc5158 | ||
|
|
e07e849cab | ||
|
|
fd51b64d2c | ||
|
|
629ad9b0c8 | ||
|
|
7fc17ff54f | ||
|
|
05c2157545 | ||
|
|
cf7ebf60e4 | ||
|
|
9f6f801829 | ||
|
|
318251899f | ||
|
|
a3fa9dc8b5 | ||
|
|
0a885c8dfa | ||
|
|
08aa8d7b53 | ||
|
|
05eb707e37 | ||
|
|
aae75a86a7 | ||
|
|
73555852ff | ||
|
|
1b7684fea9 | ||
|
|
20c7c47ddd | ||
|
|
7761553980 | ||
|
|
01c5465287 | ||
|
|
434c65e461 | ||
|
|
3e7daebcc7 | ||
|
|
4175c4a20b | ||
|
|
7902c4ae2a | ||
|
|
c488731340 | ||
|
|
6c7b51fe62 | ||
|
|
c197d5a015 | ||
|
|
b34e813dc8 | ||
|
|
a9a491db4b | ||
|
|
a6b80a7eed | ||
|
|
66ebea6cfe | ||
|
|
2be29ee963 | ||
|
|
1fc9c139cf | ||
|
|
38b44fe79f | ||
|
|
1cc922d7d9 | ||
|
|
86985e019f | ||
|
|
6a4ae37ef7 | ||
|
|
e307e6c659 | ||
|
|
722ff1561e | ||
|
|
4c68772bbf | ||
|
|
b8f596af87 | ||
|
|
e311f43d19 | ||
|
|
6803611c91 | ||
|
|
469368bf9f | ||
|
|
e79802bb12 | ||
|
|
5639e6b55c | ||
|
|
3eb6c6b7d9 | ||
|
|
d94959483f | ||
|
|
164c4c6997 | ||
|
|
167f29f5fd | ||
|
|
3cc222cf43 | ||
|
|
fd128bb692 | ||
|
|
55fe5e601d | ||
|
|
927d3db808 | ||
|
|
61bf039906 | ||
|
|
e20bfab87e | ||
|
|
63828b7256 | ||
|
|
96804aa49b | ||
|
|
dcb4a075c4 | ||
|
|
f247d0c543 | ||
|
|
a7f57b54cf | ||
|
|
5c592b4dd5 | ||
|
|
567bef9349 | ||
|
|
6bc04d9d23 | ||
|
|
67c9de101b | ||
|
|
7d380bbc44 | ||
|
|
1d580149ee | ||
|
|
8dbfd7b187 | ||
|
|
9feec0c9eb | ||
|
|
814d63f2fd | ||
|
|
4e1fd547da | ||
|
|
9edc1b9b2e | ||
|
|
c43126ba98 | ||
|
|
d5a7a50c11 | ||
|
|
66edad8a3b | ||
|
|
9ecbb353d6 | ||
|
|
fe75366bf6 | ||
|
|
14305ca64d | ||
|
|
5b1de5a348 | ||
|
|
5bb7aeb88e | ||
|
|
999b149738 | ||
|
|
745b8ee22c | ||
|
|
65110eb02a | ||
|
|
93c7c8d2d1 | ||
|
|
e2a688ce03 | ||
|
|
af7e116314 | ||
|
|
b2ce13d2b8 | ||
|
|
3cff201a9f | ||
|
|
709031afd3 | ||
|
|
b7c289048a | ||
|
|
0246f198d4 | ||
|
|
bb7e72755c | ||
|
|
1803c56862 | ||
|
|
7e63c4818f | ||
|
|
a70ab7644a | ||
|
|
5ea94512cd | ||
|
|
f3981cea50 | ||
|
|
ccfc202eac | ||
|
|
cf58891cec | ||
|
|
ab45420b88 | ||
|
|
4d6e354609 | ||
|
|
a9ba0dcaec | ||
|
|
bce4511bbb | ||
|
|
e4af3b2418 | ||
|
|
5403ede0ab | ||
|
|
d8abf18eb5 | ||
|
|
b580397423 | ||
|
|
fc4bd85342 | ||
|
|
87a148facb | ||
|
|
5866c2a57b | ||
|
|
a5345dc5c9 | ||
|
|
9aa79eacba | ||
|
|
27e3ba5880 | ||
|
|
8aff7d0e91 | ||
|
|
ecdf136c83 | ||
|
|
d33da47a2a | ||
|
|
8daa5b2260 | ||
|
|
bd6685cd34 | ||
|
|
c8fa012584 | ||
|
|
7d78a01b64 | ||
|
|
a3bbaf4940 | ||
|
|
f35e193d72 | ||
|
|
17f6b22fe7 | ||
|
|
3a10a7021a | ||
|
|
6b21455cbf | ||
|
|
c8159af975 | ||
|
|
688ed3e35c | ||
|
|
8a9e4b2387 | ||
|
|
3c04dbbde5 | ||
|
|
4dd5f72af5 | ||
|
|
37bfb6a700 | ||
|
|
8b1e6a8065 | ||
|
|
944060bef4 | ||
|
|
0944cad7ab | ||
|
|
89e4d1e01d | ||
|
|
6d07891e3f | ||
|
|
cfbff7180d | ||
|
|
f5beec83ca | ||
|
|
c286b7327e | ||
|
|
5f2a9d4be6 | ||
|
|
b4393b9617 | ||
|
|
adeddf5c45 | ||
|
|
f7ad1b00bf | ||
|
|
286f6b17bf | ||
|
|
efc2255218 | ||
|
|
6a7cfe749a | ||
|
|
d9c77a9768 | ||
|
|
c2780b7149 | ||
|
|
d07364cce2 | ||
|
|
bceedad2af | ||
|
|
c3774b0c2b | ||
|
|
6dda9a3029 | ||
|
|
55e78c72de | ||
|
|
bc91b5c790 | ||
|
|
559beab0b3 | ||
|
|
79bc624aae | ||
|
|
72d46b4049 | ||
|
|
16d4dca396 | ||
|
|
dd7a98928e | ||
|
|
8038e7050b | ||
|
|
16515e7822 | ||
|
|
e9633fbe8b | ||
|
|
3d9156d31b | ||
|
|
ef4f4a052d | ||
|
|
6c2e52acd1 | ||
|
|
566a34c9fa | ||
|
|
0f2001ce84 | ||
|
|
9a6aaa700b | ||
|
|
912e4b0977 | ||
|
|
53aa761bcd | ||
|
|
52b36079a7 | ||
|
|
75e3e3af11 | ||
|
|
6686eacae6 | ||
|
|
99e880ff5b | ||
|
|
cdced53d10 | ||
|
|
044bc77a2d | ||
|
|
81b6d45d2a | ||
|
|
069f15b5e4 | ||
|
|
b2fb4435f3 | ||
|
|
6824718e04 | ||
|
|
ba6916508e | ||
|
|
5ccd0776dd | ||
|
|
6fba68c551 | ||
|
|
b528a64177 | ||
|
|
c46a547f91 | ||
|
|
bb9538b73b | ||
|
|
b3740afbb5 | ||
|
|
695dc618c7 | ||
|
|
94e3f7f1d1 | ||
|
|
61b5110dac | ||
|
|
5ecc56fa3c | ||
|
|
9a2c5db588 | ||
|
|
6bd6b8457b | ||
|
|
d3766ed50c | ||
|
|
e9bb2115f1 | ||
|
|
e2494bc20b | ||
|
|
c46fc013f3 | ||
|
|
fcec818ba0 | ||
|
|
d8b47cd0fc | ||
|
|
2751c6eef5 | ||
|
|
6d3cc8e653 | ||
|
|
ae0355cfec | ||
|
|
73d8ea10b5 | ||
|
|
cf64ceb63c | ||
|
|
18607abac9 | ||
|
|
10bacd48a8 | ||
|
|
c209fed33d | ||
|
|
2b34c00a67 | ||
|
|
2ac0b945f5 | ||
|
|
9ae0501736 | ||
|
|
e973ce69c1 | ||
|
|
2d5fd9bfcd | ||
|
|
2fd9d25a46 | ||
|
|
a7b3af0b27 | ||
|
|
7b6f62e308 | ||
|
|
040b1f26aa | ||
|
|
43fd2a6f46 | ||
|
|
4771f9356c | ||
|
|
4f0a9b97bd | ||
|
|
795322503b | ||
|
|
e3a7754fd6 | ||
|
|
18324d6834 | ||
|
|
403e9a5dc9 | ||
|
|
c3ea2a2ffa | ||
|
|
b4960b5d3a | ||
|
|
ab1f1a6229 | ||
|
|
9b580c31b1 | ||
|
|
cb7925684d | ||
|
|
604a0b2074 | ||
|
|
39474028b4 | ||
|
|
be86229b5e | ||
|
|
dd4798bebb | ||
|
|
45af92ec27 | ||
|
|
a4f9a96b15 | ||
|
|
d122461894 | ||
|
|
7ca27ad5e6 | ||
|
|
1b6505c374 | ||
|
|
6fb1ad4242 | ||
|
|
6f4094c7c4 | ||
|
|
6d553a379a | ||
|
|
1aeb208b12 | ||
|
|
fcb5d029e2 | ||
|
|
b0c766a907 | ||
|
|
e7b04c5d38 | ||
|
|
1acc267573 | ||
|
|
2da0408b1a | ||
|
|
72387765ad | ||
|
|
4d7cd94c91 | ||
|
|
2a84fa54c2 | ||
|
|
1ac7c9608f | ||
|
|
d8e8c7fc56 | ||
|
|
1c6438de99 | ||
|
|
24503bc331 | ||
|
|
9ab8a3e7b7 | ||
|
|
d85010d460 | ||
|
|
c5c1b74381 | ||
|
|
ad89450ae6 | ||
|
|
fbfdda97e4 | ||
|
|
6223886542 | ||
|
|
73be509117 | ||
|
|
ce5c32157e | ||
|
|
06ca50cf94 | ||
|
|
1f7734acc3 | ||
|
|
9afa47b79c | ||
|
|
9f2477371a | ||
|
|
babdfc0678 | ||
|
|
bd7c45b3da | ||
|
|
42e90786b2 | ||
|
|
0004e24613 | ||
|
|
edf82faed0 | ||
|
|
71d8948654 | ||
|
|
77a53a77e7 | ||
|
|
c8cdd184e4 | ||
|
|
33c7e0139d | ||
|
|
a0c81217e2 | ||
|
|
8494dcb27b | ||
|
|
f1cd5adc70 | ||
|
|
05c4956024 | ||
|
|
cd673cd6a1 | ||
|
|
8d75f5ab41 | ||
|
|
acf35ab345 | ||
|
|
98a5ccf85c | ||
|
|
4118aa8d6b | ||
|
|
859c2baddd | ||
|
|
19c6163586 | ||
|
|
b4c36b81cb | ||
|
|
0df166101c | ||
|
|
febad02af9 | ||
|
|
8d11d92ae8 | ||
|
|
1ee4f073a3 | ||
|
|
a669125265 | ||
|
|
0cb5903e3b | ||
|
|
8c61b49a6a | ||
|
|
ff9b38712d | ||
|
|
c57533bdf9 | ||
|
|
dc1753f4d3 | ||
|
|
7a224258eb | ||
|
|
929116affc | ||
|
|
c7fd7e86bf | ||
|
|
b5dfb8768b | ||
|
|
728edfe861 | ||
|
|
b2cba6b4f1 | ||
|
|
69008c7531 | ||
|
|
066947e198 | ||
|
|
b6310c32c0 | ||
|
|
78cf0040f5 | ||
|
|
c097753801 | ||
|
|
da4264f1fd | ||
|
|
7bcafc2ab5 | ||
|
|
77fd6f2b37 | ||
|
|
cbe82179fb | ||
|
|
6b71379259 | ||
|
|
bbfa88743c | ||
|
|
bb741649d4 | ||
|
|
4e80599e03 | ||
|
|
77e9be0d3c | ||
|
|
c28203d1b4 | ||
|
|
ce670c7c0f | ||
|
|
1dafdb1c98 | ||
|
|
992331d413 | ||
|
|
aafd9edc13 | ||
|
|
63c49b4ca9 | ||
|
|
1219af36e7 | ||
|
|
162d52fc94 | ||
|
|
400fc8ab30 | ||
|
|
fd4cec66ba | ||
|
|
f9c4a5e37a | ||
|
|
a88a66615c | ||
|
|
47390a8b2c | ||
|
|
9e95c438ab | ||
|
|
e02360b2cc | ||
|
|
b0f1167eb5 | ||
|
|
ece7e8c299 | ||
|
|
e3c91880ab | ||
|
|
b62d0feed1 | ||
|
|
2525e49337 | ||
|
|
2e16b73e07 | ||
|
|
17dae849de | ||
|
|
25f001366b | ||
|
|
76dbcd49ce | ||
|
|
ddb4c798f3 | ||
|
|
ff5278a459 | ||
|
|
38a3ec1e93 | ||
|
|
be7f8c11e3 | ||
|
|
1891f423b8 | ||
|
|
b9713c4949 | ||
|
|
37727a19ee | ||
|
|
5195c49b0f | ||
|
|
3628266abd | ||
|
|
4a1cf4cf8e | ||
|
|
16d7372ac1 | ||
|
|
46a85041c8 | ||
|
|
f312e973f8 | ||
|
|
e81338ccf6 | ||
|
|
2c4f240164 | ||
|
|
73eb400e2c | ||
|
|
621d4d4756 | ||
|
|
1cdd961bd0 | ||
|
|
a315e8ea0d | ||
|
|
b5916a4347 | ||
|
|
b6b710d21b | ||
|
|
5052973dd5 | ||
|
|
e66f4218d5 | ||
|
|
fe7a19ce9c | ||
|
|
4cf370922d | ||
|
|
270ceb3829 | ||
|
|
4551038c47 | ||
|
|
ad78ab14dc | ||
|
|
61dc4984f2 | ||
|
|
4a70e280f6 | ||
|
|
576ee03ffa | ||
|
|
fa194c6dc8 | ||
|
|
0f005d2ac0 | ||
|
|
67e81d745b | ||
|
|
d7e6f14273 | ||
|
|
896942b7c4 | ||
|
|
2b79b3f35d | ||
|
|
6967cfb459 | ||
|
|
71bfd5f71e | ||
|
|
c9302b5a06 | ||
|
|
1b4e0c78db | ||
|
|
b98e6f5029 | ||
|
|
b1d88287ea | ||
|
|
4792373fa2 | ||
|
|
3429aea213 | ||
|
|
a817ff446f | ||
|
|
fc263bbf2d | ||
|
|
ed2cc4c19b | ||
|
|
b4a2483da7 | ||
|
|
711bd6c840 | ||
|
|
2e102b3248 | ||
|
|
d6b8c56967 | ||
|
|
e7a60a0fc5 | ||
|
|
8bdfaed628 | ||
|
|
6827752584 | ||
|
|
e61bbc89f3 | ||
|
|
e0ecfba967 | ||
|
|
455a540f31 | ||
|
|
cde85b6dec | ||
|
|
6994616f77 | ||
|
|
309edc74b0 | ||
|
|
119eca3dd0 | ||
|
|
8fc180e2b7 | ||
|
|
de39f29d16 | ||
|
|
3003a092dd | ||
|
|
863cd4ee18 | ||
|
|
96a90c7615 | ||
|
|
2220c3b6fb | ||
|
|
7905507e1d | ||
|
|
ff114b0bf1 | ||
|
|
78d15e770d | ||
|
|
e7eafc690b | ||
|
|
c6f924c435 | ||
|
|
7f807a137e | ||
|
|
b0306115b4 | ||
|
|
fc380486c9 | ||
|
|
02d0eb7442 | ||
|
|
312e54ce9d | ||
|
|
80ec871798 | ||
|
|
b06686fce6 | ||
|
|
cb7922e014 | ||
|
|
51f98ecc5e | ||
|
|
18b9f7c1f8 | ||
|
|
988a3c8bd3 | ||
|
|
783afff6f9 | ||
|
|
626ec6c0b1 | ||
|
|
647b38ccc2 | ||
|
|
ddffc187f9 | ||
|
|
bfe223f904 | ||
|
|
1bd6fb3e31 | ||
|
|
e78c2983db | ||
|
|
41566a983a | ||
|
|
ec7442e7c0 | ||
|
|
7c902ffc94 | ||
|
|
dff9a35be8 | ||
|
|
b33769911a | ||
|
|
9141df6ef4 | ||
|
|
899a03e05b | ||
|
|
d40380a995 | ||
|
|
49383874d5 | ||
|
|
3312447740 | ||
|
|
388d5ee96a | ||
|
|
1d9599f1ce | ||
|
|
ef9874293e | ||
|
|
3980e40773 | ||
|
|
6693faf063 | ||
|
|
aa67a0640f | ||
|
|
ac1262cc45 | ||
|
|
9f19aa18e2 | ||
|
|
891ebe004c | ||
|
|
3d26c1ab5a | ||
|
|
89a04e876e | ||
|
|
ea17f405ed | ||
|
|
e3921f4076 | ||
|
|
c344441ef9 | ||
|
|
7fa58d6b18 | ||
|
|
91886731a3 | ||
|
|
4c29afc2b3 | ||
|
|
2691f2e63f | ||
|
|
610672eacb | ||
|
|
a9c5ae704b | ||
|
|
5775934cfd | ||
|
|
c8b1eb50e7 | ||
|
|
0f7b731d1b | ||
|
|
6cf472f1c2 | ||
|
|
4b42a9c7fa | ||
|
|
1d9f7e12c7 | ||
|
|
03868ef221 | ||
|
|
0d3b911f25 | ||
|
|
6aca775b27 | ||
|
|
b9bf492940 | ||
|
|
2d0e996a7b | ||
|
|
4c73ea48a6 | ||
|
|
acbc648af9 | ||
|
|
24a9bcb3ed | ||
|
|
f36fe7a20b | ||
|
|
6593048018 | ||
|
|
bcd762fca4 | ||
|
|
1b779dd916 | ||
|
|
f6869de484 | ||
|
|
7c6311786d | ||
|
|
df513395ac | ||
|
|
8b1e92caf5 | ||
|
|
e141ca6c53 | ||
|
|
6add1f6fe4 | ||
|
|
37ba41d514 | ||
|
|
8c7695c351 | ||
|
|
06b24022fb | ||
|
|
3a308f6d80 | ||
|
|
bc7927c74f | ||
|
|
75d8e8cd79 | ||
|
|
99fd8f4abb | ||
|
|
dae1aff342 | ||
|
|
4a8b98cd95 | ||
|
|
e078dfe493 | ||
|
|
e1dce6b98e | ||
|
|
c71ebf0470 | ||
|
|
fb7b8d23ed | ||
|
|
32c4657377 | ||
|
|
0f7b9ef00b | ||
|
|
8213357795 | ||
|
|
2d8a383ddd | ||
|
|
7e44ee64bb | ||
|
|
f7e81eb914 | ||
|
|
eabe96905b | ||
|
|
2d2f55a5af | ||
|
|
80e85aea43 | ||
|
|
91fbcc1a11 | ||
|
|
c737440708 | ||
|
|
ec2c82db83 | ||
|
|
3b79dad306 | ||
|
|
bf68e143c5 | ||
|
|
e83c5d93c9 | ||
|
|
cc4654a716 | ||
|
|
e1128005a1 | ||
|
|
611b6bf5e5 | ||
|
|
4fd1eaf0dd | ||
|
|
e0f2200872 | ||
|
|
5d2b3101ec | ||
|
|
7720024e34 | ||
|
|
420e4bfbdd | ||
|
|
6bb7ed82fa | ||
|
|
69ef93aa5c | ||
|
|
9293787fa5 | ||
|
|
4883a04860 | ||
|
|
1575c042ba | ||
|
|
ddb56ae7ed | ||
|
|
b05c411cc7 | ||
|
|
19974ae103 | ||
|
|
63d80c036a | ||
|
|
25686b2f45 | ||
|
|
56c8e8651e | ||
|
|
89f849c696 | ||
|
|
a6862e646b | ||
|
|
3d2b98418d | ||
|
|
958187f89c | ||
|
|
24fe67aef7 | ||
|
|
76639795c5 | ||
|
|
2e8c96275b | ||
|
|
85ca3f3236 | ||
|
|
b796ff9f49 | ||
|
|
72210aff74 | ||
|
|
340ab6ea8a | ||
|
|
51db30d469 | ||
|
|
11c13393e2 | ||
|
|
8f4b447757 | ||
|
|
815e76eb9c | ||
|
|
6a1ea81d70 | ||
|
|
afcbdcc291 | ||
|
|
fca23ab21b | ||
|
|
57ec1d9fc5 | ||
|
|
a59f05a801 | ||
|
|
5ecefbd403 | ||
|
|
c611b61a1a | ||
|
|
84d90e5d07 | ||
|
|
653718418a | ||
|
|
b33372b66b | ||
|
|
d3e307c276 | ||
|
|
af2636009a | ||
|
|
29609f4089 | ||
|
|
0b09c7378a | ||
|
|
818f942eaa | ||
|
|
71f05594ae | ||
|
|
cfa4cf1419 | ||
|
|
f663b592e7 | ||
|
|
1b8d6ed5e3 | ||
|
|
7cb774c127 | ||
|
|
9cc783bb47 | ||
|
|
83633084bd | ||
|
|
e2ea32d075 | ||
|
|
4082c11bd8 | ||
|
|
a80f6cfc55 | ||
|
|
82597772ab | ||
|
|
05b9d85074 | ||
|
|
921c1f2b23 | ||
|
|
a3a4d929ca | ||
|
|
2fd3d6ee92 | ||
|
|
ff8ce3b365 | ||
|
|
619d25897d | ||
|
|
a965d30d28 | ||
|
|
81d0afa366 | ||
|
|
e0dc1e8aa4 | ||
|
|
2c574e4885 | ||
|
|
43e2d1da15 | ||
|
|
c9afe7fb8e | ||
|
|
caa2f23cd4 | ||
|
|
b2adb8ee49 | ||
|
|
ca0d0d4cb1 | ||
|
|
458eb79ee0 | ||
|
|
194f56b8d3 | ||
|
|
eeffa6ab01 | ||
|
|
862a86d4a8 | ||
|
|
3f0c5aa8f6 | ||
|
|
8eaf21fc0b | ||
|
|
8b8045504b | ||
|
|
dd8ae5b234 | ||
|
|
59705465f2 | ||
|
|
d367563902 | ||
|
|
d705b7cac2 | ||
|
|
20dcb4a1d1 | ||
|
|
610caecbc1 | ||
|
|
eee9660d58 | ||
|
|
7caed0c027 | ||
|
|
a5427040d6 | ||
|
|
3dcd172445 | ||
|
|
49cd19fd46 | ||
|
|
6a6bae59e1 | ||
|
|
52cba19a5c | ||
|
|
36df9913a1 | ||
|
|
0a845357fc | ||
|
|
799bb4006f | ||
|
|
7623cb11f5 | ||
|
|
90fa7546b2 | ||
|
|
eda56a5859 | ||
|
|
11c05f3c94 | ||
|
|
bf26a4ca10 | ||
|
|
df1a65df90 | ||
|
|
9cd11cdf66 | ||
|
|
cfd793a8af | ||
|
|
af110e350a | ||
|
|
a1d932e4ee | ||
|
|
0ed0757094 | ||
|
|
da67983385 | ||
|
|
3c53d7bffc | ||
|
|
702c14d5ac | ||
|
|
c2caead0c8 | ||
|
|
a9c094851c | ||
|
|
55335db9e3 | ||
|
|
8936d6cb00 | ||
|
|
43495862cc | ||
|
|
2c09787cbd | ||
|
|
49aa61ea56 | ||
|
|
ba3e149ac6 | ||
|
|
ed7ccd3d03 | ||
|
|
65b2425052 | ||
|
|
16a5dd9520 | ||
|
|
09cecef79b | ||
|
|
4ee414a676 | ||
|
|
3d30e413ee | ||
|
|
62622b1e84 | ||
|
|
821e0eeb57 | ||
|
|
d9f5302844 | ||
|
|
dd2a7133d0 | ||
|
|
d551877a7b | ||
|
|
7e004ed6cc | ||
|
|
70f8f983f8 | ||
|
|
249cb79257 | ||
|
|
29299afffc | ||
|
|
e142584be5 | ||
|
|
6291119c4a | ||
|
|
b53183875a | ||
|
|
e6580c0cad | ||
|
|
2b1dc29ab0 | ||
|
|
d655193d6f | ||
|
|
364be3c0fe | ||
|
|
df06ee22f2 | ||
|
|
8aca156256 | ||
|
|
af7aea382a | ||
|
|
60bb42a26b | ||
|
|
41197ef864 | ||
|
|
f711f471da | ||
|
|
d6c2d58d2b | ||
|
|
183d2215f4 | ||
|
|
6397f6e797 | ||
|
|
1c1b303b41 | ||
|
|
84a849fdcf | ||
|
|
96f93bade1 | ||
|
|
483ed2860c | ||
|
|
572bd1eaeb | ||
|
|
28ba1c0a9d | ||
|
|
5b621832df | ||
|
|
3510d90ec0 | ||
|
|
8c5cf1575f | ||
|
|
019a9152db | ||
|
|
baf63140b3 | ||
|
|
84a96cecec | ||
|
|
b6d8d87d32 | ||
|
|
502ea4a67c | ||
|
|
b5c8b560a2 | ||
|
|
cdf50398c1 | ||
|
|
478d7e56e1 | ||
|
|
b5ac99a5e2 | ||
|
|
92402b88b4 | ||
|
|
1e2aa9d187 | ||
|
|
38562ebeb6 | ||
|
|
55cde2572f | ||
|
|
f30616ce42 | ||
|
|
246495fe4c | ||
|
|
25d541d717 | ||
|
|
146e4d9466 | ||
|
|
5b8150662c | ||
|
|
86c9bf3750 | ||
|
|
beca927dab | ||
|
|
5f6b3240fa | ||
|
|
fa89b0f280 | ||
|
|
831b8ab578 | ||
|
|
6ce1f992aa | ||
|
|
60dce6fe60 | ||
|
|
1c7b226f3a | ||
|
|
3c596d647d | ||
|
|
13bb1c1117 | ||
|
|
214302fc11 | ||
|
|
61c79318ad | ||
|
|
286b33864d | ||
|
|
bda7abe112 | ||
|
|
b726c80da0 | ||
|
|
588b3d93d3 | ||
|
|
0baea7a374 | ||
|
|
af13e6591d | ||
|
|
4167d8d1c6 | ||
|
|
ea0eeabf71 | ||
|
|
133c9476a6 | ||
|
|
34aff30749 | ||
|
|
14af91a47a | ||
|
|
ce2a0931b6 | ||
|
|
45c90ed988 | ||
|
|
447f7eca30 | ||
|
|
7d0d84f0c7 | ||
|
|
990935105f | ||
|
|
14c00670e2 | ||
|
|
a0e801fc9b | ||
|
|
f6c363f4ff | ||
|
|
9b5a4519f3 | ||
|
|
b6fefd8219 | ||
|
|
0159b2b79d | ||
|
|
fb49b7964d | ||
|
|
e19479c22e | ||
|
|
ab0d625e36 | ||
|
|
a01b000bdc | ||
|
|
f425f28ec0 | ||
|
|
f6bdc70006 | ||
|
|
20d4d031dd | ||
|
|
6d23b30471 | ||
|
|
f3e1fb7e2b | ||
|
|
1e4cdcddd1 | ||
|
|
ccfb7ac221 | ||
|
|
959cfc08b6 | ||
|
|
941c2896ec | ||
|
|
22dd209969 | ||
|
|
9d199fb4ae | ||
|
|
1c8242fcef | ||
|
|
0ef5531d24 | ||
|
|
1e897be870 | ||
|
|
2a27456795 | ||
|
|
1e32111a32 | ||
|
|
dae6de87e0 | ||
|
|
5b9fe61434 | ||
|
|
369c45fa11 | ||
|
|
6df7f603c4 | ||
|
|
7488acfbbc | ||
|
|
5792ba43da | ||
|
|
e781c7f2fa | ||
|
|
299ba20dd2 | ||
|
|
b4da32804f | ||
|
|
1e2b428a31 | ||
|
|
83d1456bd3 | ||
|
|
c8a6600afa | ||
|
|
6e0e2ad4fa | ||
|
|
b3c630fd80 | ||
|
|
75a52c1d15 | ||
|
|
17de458ad6 | ||
|
|
1354659b85 | ||
|
|
11e54ac11f | ||
|
|
fbb59e601f | ||
|
|
925d52f416 | ||
|
|
6dc42d1139 | ||
|
|
b585ba14d4 | ||
|
|
7108fc9c6c | ||
|
|
8213f855d0 | ||
|
|
152b7719a2 | ||
|
|
1abdbe3e2f | ||
|
|
893f514974 | ||
|
|
68a6386741 | ||
|
|
63d0b48c19 | ||
|
|
94d759700a | ||
|
|
2a8682bf68 | ||
|
|
ad8ab1cb21 | ||
|
|
df3095c2d3 | ||
|
|
51e0848468 | ||
|
|
ca7ea18785 | ||
|
|
c808143f0b | ||
|
|
6b20a3b125 | ||
|
|
777e5ff937 | ||
|
|
fc0c8ac625 | ||
|
|
13eac75ebe | ||
|
|
981abb0d4b | ||
|
|
7fe7fef0fb | ||
|
|
fcc648271a | ||
|
|
4da2dddd7b | ||
|
|
3650bd14fd | ||
|
|
df3dfee373 | ||
|
|
c6f1209725 | ||
|
|
13f45228e5 | ||
|
|
ba6ada2692 | ||
|
|
d393de38dc | ||
|
|
9f0ae1f44c | ||
|
|
2fe2b8692f | ||
|
|
c5cb80b346 | ||
|
|
bd9ac66548 | ||
|
|
186324ac08 | ||
|
|
575ea3e7d7 | ||
|
|
d8614f80a6 | ||
|
|
f6dd920649 | ||
|
|
ef0989f7e7 | ||
|
|
b0471ef883 | ||
|
|
a9f739b35d | ||
|
|
b4b4fb3528 | ||
|
|
ac2ba8ae1a | ||
|
|
1f52c5054b | ||
|
|
186fc17584 | ||
|
|
2aef15d9fb | ||
|
|
02da577152 | ||
|
|
a67f36fdfa | ||
|
|
7ad8e806dc | ||
|
|
8bece83925 | ||
|
|
6b37863a7b | ||
|
|
a00336f3dc | ||
|
|
2bec02cc45 | ||
|
|
a89ef5a4e6 | ||
|
|
1a15bd9edb | ||
|
|
88f3437815 | ||
|
|
f68b8ccb58 | ||
|
|
b36936693f | ||
|
|
9b2e7c16fc | ||
|
|
3cd78541b2 | ||
|
|
337a02cb76 | ||
|
|
204726f487 | ||
|
|
59f6cb5272 | ||
|
|
6a4a3639af | ||
|
|
0d01683601 | ||
|
|
6c882bd642 | ||
|
|
e9412dcf4a | ||
|
|
58f742200b | ||
|
|
75ba8c2adf | ||
|
|
ada6ae5c12 | ||
|
|
eaca4e29a3 | ||
|
|
0593b6d8d4 | ||
|
|
357baf08ad | ||
|
|
72e4ab8c17 | ||
|
|
51b4df4b6c | ||
|
|
ec816c41b8 | ||
|
|
3905681d67 | ||
|
|
adc1d04fa1 | ||
|
|
08d15e2b9c | ||
|
|
8c952c6649 | ||
|
|
b1471bc78d | ||
|
|
7326e385a8 | ||
|
|
992c546f2b | ||
|
|
1977509c1f | ||
|
|
51bac735e1 | ||
|
|
e98f3fceb3 | ||
|
|
4c4ee4f2c1 | ||
|
|
52a818520c | ||
|
|
426a98c8bc | ||
|
|
397e1c1de6 | ||
|
|
4886962a41 | ||
|
|
e06fc06745 | ||
|
|
065c919720 | ||
|
|
7452cc7dc6 | ||
|
|
92c55fa13a | ||
|
|
e94f2d7e1d | ||
|
|
506591c3d8 | ||
|
|
ca5b579f4b | ||
|
|
4de0dc3433 | ||
|
|
e2a1aa81f9 | ||
|
|
6ef7433396 | ||
|
|
60fd245e73 | ||
|
|
853c0cfc99 | ||
|
|
47930ff0cb | ||
|
|
69450aeb77 | ||
|
|
92229ee6bf | ||
|
|
4d9ab23a51 | ||
|
|
454037295f | ||
|
|
386d6a5b7c | ||
|
|
b3c13c6cfb | ||
|
|
5c7e66249d | ||
|
|
e363f145a1 | ||
|
|
65a90ed198 | ||
|
|
6cbf598d2f | ||
|
|
d4990525c7 | ||
|
|
49ce694fe2 | ||
|
|
ad483e3e09 | ||
|
|
93580cb58b | ||
|
|
b1083ab3c4 | ||
|
|
88fcf7cb50 | ||
|
|
d5593e5f80 | ||
|
|
177b2f0744 | ||
|
|
13f0286788 | ||
|
|
4274e43ced | ||
|
|
65bd615d62 | ||
|
|
bb20d83961 | ||
|
|
e116db6971 | ||
|
|
b3a34ee194 | ||
|
|
54d51b829a | ||
|
|
6d592a7503 | ||
|
|
fc040b4e21 | ||
|
|
9943c03f53 | ||
|
|
fe6528229a | ||
|
|
0532d1c22b | ||
|
|
bc16e6d487 | ||
|
|
dafd7385ab | ||
|
|
1b47314695 | ||
|
|
3a7e8a8bea | ||
|
|
668638dbc7 | ||
|
|
71ca9b484f | ||
|
|
1f21fb4aa2 | ||
|
|
6982691483 | ||
|
|
5b5140d2d7 | ||
|
|
a6540b5f26 | ||
|
|
bffcf39b22 | ||
|
|
76ed0a2981 | ||
|
|
597ae10a14 | ||
|
|
2e7e07d0f9 | ||
|
|
f279db3650 | ||
|
|
b8d5d9e893 | ||
|
|
1dc8cf5a3e | ||
|
|
0d13d02c1c | ||
|
|
4bf2f9c703 | ||
|
|
b7495e5f55 | ||
|
|
d67ddb5f2d | ||
|
|
cfc56b03b0 | ||
|
|
43721f5437 | ||
|
|
4439cdc4fd | ||
|
|
714ce1e77d | ||
|
|
f15c121252 | ||
|
|
bd3338e65d | ||
|
|
ae977f0aa8 | ||
|
|
c7c40b7551 | ||
|
|
2a598d0a9b | ||
|
|
4986206ca0 | ||
|
|
0810c19168 | ||
|
|
00643c6620 | ||
|
|
9507d33945 | ||
|
|
cbdb0088c5 | ||
|
|
0c3eba4dc1 | ||
|
|
344b46880c | ||
|
|
0457f201c8 | ||
|
|
616ba9874e | ||
|
|
582954d10f | ||
|
|
a3670020dd | ||
|
|
cc506f0c82 | ||
|
|
b40f360956 | ||
|
|
12ba59e5fc | ||
|
|
a93abde5f2 | ||
|
|
ce639aabe4 | ||
|
|
11c958956f | ||
|
|
f99b94ded1 | ||
|
|
db70e8ea7f | ||
|
|
78147b5279 | ||
|
|
c923390193 | ||
|
|
d472f1b7ef | ||
|
|
c8b8291940 | ||
|
|
cd9d3be884 | ||
|
|
b94885a84c | ||
|
|
b6c512bf2d | ||
|
|
2861ad1ce0 | ||
|
|
4c9733d702 | ||
|
|
64bd56ab06 | ||
|
|
6778e7bf68 | ||
|
|
31855e8f72 | ||
|
|
2c0e05ee6d | ||
|
|
7d13773c0b | ||
|
|
5a7c846539 | ||
|
|
2eeeb0c8c5 | ||
|
|
2bc2154dcd | ||
|
|
a8f3296e4b | ||
|
|
abc2c10054 | ||
|
|
ad67e9e2dd | ||
|
|
a7674c8ad0 | ||
|
|
bd7957c22e | ||
|
|
9694b35d75 | ||
|
|
f8390a7118 | ||
|
|
1162300ed3 | ||
|
|
23489d3f23 | ||
|
|
ecc34c2227 | ||
|
|
9053a42a3c | ||
|
|
8552c93ebb | ||
|
|
4e207f3638 | ||
|
|
3f675ed4a4 | ||
|
|
042f118ef8 | ||
|
|
54deef2704 | ||
|
|
2faeff52ad | ||
|
|
b322a6aa64 | ||
|
|
9720860c11 | ||
|
|
d4fc73b083 | ||
|
|
b6b4ed47f4 | ||
|
|
8f35c7c6ab | ||
|
|
65f6b2d36d | ||
|
|
6d9868f52c | ||
|
|
bc43b98b75 | ||
|
|
b5446c6b8f | ||
|
|
a34c63228b | ||
|
|
5470d10df8 | ||
|
|
6e6324b738 | ||
|
|
fd63e11237 | ||
|
|
5ce266dd9e | ||
|
|
8f9d7ba0e5 | ||
|
|
4f5f49b8ef | ||
|
|
9b9dc220d2 | ||
|
|
b20ff47127 | ||
|
|
cf222b9e7a | ||
|
|
8fa5ab6219 | ||
|
|
846b431942 | ||
|
|
1fb1f9057e | ||
|
|
05de7098f7 | ||
|
|
c30bba1bcf | ||
|
|
6267a5533c | ||
|
|
5579494979 | ||
|
|
c4cf17c448 | ||
|
|
71ec6960ee | ||
|
|
06faac014d | ||
|
|
3f5193c2f0 | ||
|
|
8676c7d2e6 | ||
|
|
3f4e94f994 | ||
|
|
7f8a4b9d15 | ||
|
|
753d7ec3b4 | ||
|
|
07b3edb20b | ||
|
|
6286e8039a | ||
|
|
965f305152 | ||
|
|
2c5370239d | ||
|
|
3d748f5273 | ||
|
|
ddb632ac13 | ||
|
|
009541d133 | ||
|
|
7dffd9af9a | ||
|
|
b3fdd76177 | ||
|
|
93dfefd860 | ||
|
|
744986b7f1 | ||
|
|
f3f7749360 | ||
|
|
b6cd19f7ba | ||
|
|
5c82aee19b | ||
|
|
c78ed7f1fa | ||
|
|
2dac530db0 | ||
|
|
6ba33f8b1c | ||
|
|
bfbd2211fe | ||
|
|
8e09fcaa7d | ||
|
|
3f9fa1b202 | ||
|
|
a828a92953 | ||
|
|
fe8f29488e | ||
|
|
eaaab0063b | ||
|
|
7188b07f43 | ||
|
|
cdb39d5f18 | ||
|
|
df694aa951 | ||
|
|
c249355a42 | ||
|
|
8cd836b421 | ||
|
|
86e75cb465 | ||
|
|
10938b57a1 | ||
|
|
ff551045d5 | ||
|
|
8eff8f8cfb | ||
|
|
720e9691c1 | ||
|
|
eefc2b2658 | ||
|
|
2b7a3c14db | ||
|
|
2952aff355 | ||
|
|
b9df23072d | ||
|
|
0955b5339c | ||
|
|
7c0e3dec64 | ||
|
|
8519a01099 | ||
|
|
2d5497513a | ||
|
|
0232695ebe | ||
|
|
452964a882 | ||
|
|
5cb18ec227 | ||
|
|
79290db683 | ||
|
|
f75be67768 | ||
|
|
bd7bc23d8c | ||
|
|
64e090af69 | ||
|
|
568c87f5ba | ||
|
|
955353cb59 | ||
|
|
15e95081fd | ||
|
|
a739f70776 | ||
|
|
a80002e015 | ||
|
|
395e806665 | ||
|
|
2af50acb2b | ||
|
|
9c95da6b40 | ||
|
|
53fdbf54a7 | ||
|
|
028d45b39b | ||
|
|
4de2288096 | ||
|
|
fb31d00907 | ||
|
|
e7e6ccfc40 | ||
|
|
951b534d29 | ||
|
|
3265860819 | ||
|
|
c9a734814e | ||
|
|
f5d5fab54f | ||
|
|
a55e047f20 | ||
|
|
2e281b6ca3 | ||
|
|
337d0e5629 | ||
|
|
efc2d2ee63 | ||
|
|
2aff1064ee | ||
|
|
55ab3cdd45 | ||
|
|
dd3688b9ce | ||
|
|
e99451e72c | ||
|
|
e7dc9ed7f6 | ||
|
|
cc8ace5b95 | ||
|
|
dcb3ddb3fc | ||
|
|
f656bdc676 | ||
|
|
87af8d0aa5 | ||
|
|
41ba54ddb6 | ||
|
|
524f9b4c20 | ||
|
|
564653926e | ||
|
|
a43e63cd42 | ||
|
|
2f55ab8b71 | ||
|
|
538b201d0d | ||
|
|
0e0bf77274 | ||
|
|
de395f4659 | ||
|
|
44f4ba2d25 | ||
|
|
6172445028 | ||
|
|
76f1cf30ee | ||
|
|
b68cb52de6 | ||
|
|
1a5559b359 | ||
|
|
84940ba2a5 | ||
|
|
f22f65cf45 | ||
|
|
2a765e88b6 | ||
|
|
08415507b0 | ||
|
|
45602e9e65 | ||
|
|
9f2d838fc6 | ||
|
|
d2f6181114 | ||
|
|
1e5100b8a1 | ||
|
|
2a4d8e0a25 | ||
|
|
e6dbf12f0a | ||
|
|
90390417df | ||
|
|
b62c56b3dd | ||
|
|
da21e46cd3 | ||
|
|
a2c9a56a36 | ||
|
|
e1aef2390e | ||
|
|
5de2d83b43 | ||
|
|
306934733c | ||
|
|
75cb9970be | ||
|
|
3102132019 | ||
|
|
4489689f71 | ||
|
|
6ad4c2c0a1 | ||
|
|
7f4e95884f | ||
|
|
74847f83b5 | ||
|
|
e4bb8e61b0 | ||
|
|
f7726082d3 | ||
|
|
477d7891f0 | ||
|
|
606e882015 | ||
|
|
118473af52 | ||
|
|
60497c47a0 | ||
|
|
3c4d21c9c2 | ||
|
|
2349ff780b | ||
|
|
456f03afec | ||
|
|
ab04cc203d | ||
|
|
8f077a272d | ||
|
|
e7c55f01db | ||
|
|
ce530f7ea3 | ||
|
|
8b3c52d049 | ||
|
|
5b7144f004 | ||
|
|
b32faf6cc0 | ||
|
|
b897e9896e | ||
|
|
aa8bfb5554 | ||
|
|
13f1026d7a | ||
|
|
d723289148 | ||
|
|
bf1c637528 | ||
|
|
b47fcf10b9 | ||
|
|
ea49b0cbca | ||
|
|
b720a6f3f9 | ||
|
|
7bcf968253 | ||
|
|
12114e4e08 | ||
|
|
ebc37d14b4 | ||
|
|
3310d79e1a | ||
|
|
8f8bca227a | ||
|
|
a0ee315857 | ||
|
|
5cfb5c8b38 | ||
|
|
e720d07c79 | ||
|
|
869816ffe0 | ||
|
|
966ad936fa | ||
|
|
928e88ce22 | ||
|
|
edfaa243ea | ||
|
|
8b22a78f32 | ||
|
|
d00d22b1c4 | ||
|
|
e27e0eafd0 | ||
|
|
378bb9322b | ||
|
|
b587691b16 | ||
|
|
aa39c4b4aa | ||
|
|
e1897b27b5 | ||
|
|
ea10f794cd | ||
|
|
7391776b2a | ||
|
|
ae671e2b91 | ||
|
|
1dacdfc4c6 | ||
|
|
c97e7263f7 | ||
|
|
b5e965ef09 | ||
|
|
96cd8b3420 | ||
|
|
e8c881c8e0 | ||
|
|
a6b82288bc | ||
|
|
2eb1451f91 | ||
|
|
7839c58641 | ||
|
|
aa8bd39666 | ||
|
|
61ed03dd46 | ||
|
|
ac6cf0393b | ||
|
|
078e8d67f5 | ||
|
|
c4d485ef8c | ||
|
|
12b0177500 | ||
|
|
9ce9dc654f | ||
|
|
e123dc64f4 | ||
|
|
640fe76319 | ||
|
|
36ce140e43 | ||
|
|
271f1d0549 | ||
|
|
ff2abb98d3 | ||
|
|
fa6d7b204b | ||
|
|
7d7931aec4 | ||
|
|
721b78ee49 | ||
|
|
239ea49727 | ||
|
|
520d0fd42e | ||
|
|
60093266ae | ||
|
|
dc46fef981 | ||
|
|
526f073ec6 | ||
|
|
28f52822c9 | ||
|
|
314c139b9e | ||
|
|
ff66ac48b3 | ||
|
|
a59f70805a | ||
|
|
ce8a4ab9e6 | ||
|
|
6c851594f0 | ||
|
|
a765b8f5d6 | ||
|
|
33f8192790 | ||
|
|
0b6e73197b | ||
|
|
b241f143db | ||
|
|
987d3d0316 | ||
|
|
539ab11985 | ||
|
|
779c77ac21 | ||
|
|
7e156aa654 | ||
|
|
68ff00fd8b | ||
|
|
4320d836e1 | ||
|
|
8a4be18b77 | ||
|
|
c08f3b3c80 | ||
|
|
4565dd1dc0 | ||
|
|
0f735aa2a4 | ||
|
|
396c70c16e | ||
|
|
2acd7638cc | ||
|
|
78afeb1674 | ||
|
|
b1c76184a1 | ||
|
|
3551214ac0 | ||
|
|
22efec2b64 | ||
|
|
ef28037143 | ||
|
|
f6ebebfc27 | ||
|
|
24c669d9aa | ||
|
|
0a82ab43e6 | ||
|
|
e3f14f93d1 | ||
|
|
1e14068343 | ||
|
|
aac130469c | ||
|
|
3d5fbd3053 | ||
|
|
c24776265d | ||
|
|
66e9c0dfcc | ||
|
|
57aa4a816b | ||
|
|
e2d42c702e | ||
|
|
becce8cd21 | ||
|
|
e8bbfc7b88 | ||
|
|
a43f3f97c2 | ||
|
|
87d9000d0f | ||
|
|
d3a17633aa | ||
|
|
955002df6c | ||
|
|
28af33211c | ||
|
|
f5d5a1973d | ||
|
|
e4a8b9d316 | ||
|
|
adbaad4069 | ||
|
|
9606911f7f | ||
|
|
f574629a08 | ||
|
|
7e0f0872ae | ||
|
|
73e9d937f1 | ||
|
|
675d578036 | ||
|
|
94e1102a42 | ||
|
|
41dac7db23 | ||
|
|
a379e76138 | ||
|
|
08a2f076a1 | ||
|
|
09f9431d23 | ||
|
|
038224b51c | ||
|
|
61e9ad9f57 | ||
|
|
9336a78274 | ||
|
|
e4d4880971 | ||
|
|
db96ca46e2 | ||
|
|
590cf5dde0 | ||
|
|
814058acf1 | ||
|
|
9edc40831e | ||
|
|
16ae54ece3 | ||
|
|
472dd9f563 | ||
|
|
b2359023d6 | ||
|
|
c379c45b45 | ||
|
|
96d4ac23e1 | ||
|
|
d727292d39 | ||
|
|
8a96862162 | ||
|
|
e25facbde1 | ||
|
|
11ea6dd63c | ||
|
|
8eae65ef03 | ||
|
|
cb8bc681cf | ||
|
|
af550576e8 | ||
|
|
1659f22e4f | ||
|
|
ec43d15906 | ||
|
|
3acfc6ef84 | ||
|
|
6376c77a07 | ||
|
|
0042005fde | ||
|
|
e503e4f52c | ||
|
|
0454c6f9c3 | ||
|
|
d05cc4ae3e | ||
|
|
8bf3486d6d | ||
|
|
1c9671e2d0 | ||
|
|
6bfe1fb9a9 | ||
|
|
e13e0c1002 | ||
|
|
f874db085d | ||
|
|
b8be04bb47 | ||
|
|
57a4db49d4 | ||
|
|
c5b9658ba0 | ||
|
|
fddc825d0f | ||
|
|
5208b6f8ad | ||
|
|
193a4a5845 | ||
|
|
6ec0bcd32f | ||
|
|
793a090bf5 | ||
|
|
5f8fafc559 | ||
|
|
b2ac4e2b9c | ||
|
|
92a8e56228 | ||
|
|
fdc7260040 | ||
|
|
14c34e3128 | ||
|
|
ed1a25aea5 | ||
|
|
1c38259279 | ||
|
|
2e80db6b55 | ||
|
|
2d23508c8a | ||
|
|
486f0283b8 | ||
|
|
7e22978393 | ||
|
|
4d857ad62e | ||
|
|
a5cfdee69a | ||
|
|
d58b2dc6b3 | ||
|
|
1fad7d011d | ||
|
|
f4ef16f727 | ||
|
|
94ff1151b7 | ||
|
|
140a597ebd | ||
|
|
121d5e86cb | ||
|
|
51f533a3d6 | ||
|
|
c3edbe2528 | ||
|
|
cb0606b8ba | ||
|
|
35886fdf28 | ||
|
|
a5684dfc58 | ||
|
|
e55199d2b2 | ||
|
|
7efece4c16 | ||
|
|
b50e3aeab5 | ||
|
|
ae3d58b76f | ||
|
|
d4fb901288 | ||
|
|
e7e3e5e7e1 | ||
|
|
263dbbaea9 | ||
|
|
64f406d532 | ||
|
|
416c725017 | ||
|
|
151b89ac03 | ||
|
|
f2e782cf95 | ||
|
|
e16a40c84c | ||
|
|
4a906fb5be | ||
|
|
58b8c62dc7 | ||
|
|
d9d8f6e325 | ||
|
|
2af6ccbe58 | ||
|
|
15d1c835b0 | ||
|
|
f55a0cebea | ||
|
|
e508fbd614 | ||
|
|
22b9642add | ||
|
|
c78b5a2bf8 | ||
|
|
7f363d07b6 | ||
|
|
b22dfc8f61 | ||
|
|
1747ce3b6d | ||
|
|
487e985a3e | ||
|
|
bdff18dd76 | ||
|
|
6e6064b6e6 | ||
|
|
a6925f69bf | ||
|
|
149a379a19 | ||
|
|
23df1e5e8a | ||
|
|
07a7e342ec | ||
|
|
37f00e57b5 | ||
|
|
19a70d3d31 | ||
|
|
cf2b486447 | ||
|
|
8ed413d777 | ||
|
|
8b40c2385c | ||
|
|
9a1a1435c0 | ||
|
|
2f9db198e6 | ||
|
|
e3b48b556d | ||
|
|
fac688e128 | ||
|
|
2b521b56f9 | ||
|
|
369cf7ea09 | ||
|
|
490e7b7f63 | ||
|
|
8bf712378d | ||
|
|
4986a13d53 | ||
|
|
6eb8242134 | ||
|
|
8add4d1e05 | ||
|
|
02a28ad7fc | ||
|
|
4c733dd928 | ||
|
|
6372fcf5c1 | ||
|
|
5a5a1f9e23 | ||
|
|
9117eab57d | ||
|
|
e1c865575e | ||
|
|
975bb07ba7 | ||
|
|
aba2766aae | ||
|
|
9743bc8d49 | ||
|
|
88794bd848 | ||
|
|
8f06d2d963 | ||
|
|
d074e81201 | ||
|
|
77c4e5ebbc | ||
|
|
e8fedf4532 | ||
|
|
71d6890e1b | ||
|
|
86224a4baf | ||
|
|
8775524325 | ||
|
|
7aa758eeb5 | ||
|
|
c6168eeda6 | ||
|
|
90f89d1d54 | ||
|
|
7e9573ba40 | ||
|
|
ed05607cd8 | ||
|
|
40713da413 | ||
|
|
c79763b1a9 | ||
|
|
bd780df1db | ||
|
|
44bf2a78e9 | ||
|
|
c407fbc3a5 | ||
|
|
92ca72deb6 | ||
|
|
d796fe1f4e | ||
|
|
74463085d6 | ||
|
|
7ac38346b5 | ||
|
|
d078eeed78 | ||
|
|
dddbcc0746 | ||
|
|
f87501f0d4 | ||
|
|
4adc9a7646 | ||
|
|
ed92bf23fd | ||
|
|
dddd613773 | ||
|
|
a06002d3d7 | ||
|
|
d96a3fd61a | ||
|
|
cd5a1d9c6e | ||
|
|
64e9a24564 | ||
|
|
64c20956eb | ||
|
|
db7cf8a6a3 | ||
|
|
abe15a3d50 | ||
|
|
d919f6dd35 | ||
|
|
d00d812267 | ||
|
|
1b81d44aea | ||
|
|
cdfc0c793b | ||
|
|
77b374e263 | ||
|
|
0c1cc485ed | ||
|
|
be1fa7e8b9 | ||
|
|
ca659ea85a | ||
|
|
3ad14daa2e | ||
|
|
7b3d18e5a1 | ||
|
|
968de9e599 | ||
|
|
feb0e8498a | ||
|
|
53c919642c | ||
|
|
8b01730e53 | ||
|
|
bba0ec77b9 | ||
|
|
458b4ec409 | ||
|
|
0566d64e05 | ||
|
|
5e5e040af3 | ||
|
|
7e9b61cbc0 | ||
|
|
7cc9d3b246 | ||
|
|
5507c169f7 | ||
|
|
ae2eddb822 | ||
|
|
1befe63f01 | ||
|
|
2dbec15983 | ||
|
|
e33dd0ccb5 | ||
|
|
9bb678fdd0 | ||
|
|
d9bec21bb8 | ||
|
|
5d8da66d1c | ||
|
|
c57d1caa65 | ||
|
|
cab91f165e | ||
|
|
afb9d1e2af | ||
|
|
035f3fe957 | ||
|
|
d22cbfae61 | ||
|
|
6afec88cbb | ||
|
|
4d9f673c03 | ||
|
|
fdaed2a9ed | ||
|
|
4fa659b3cc | ||
|
|
1f5b09a058 | ||
|
|
2ec250ab3c | ||
|
|
4b4811e586 | ||
|
|
1846d00f58 | ||
|
|
3955de2af2 | ||
|
|
b9662d1f3c | ||
|
|
c15de5b98c | ||
|
|
db148cdd4d | ||
|
|
0ab0c55d65 | ||
|
|
89e55c3c3a | ||
|
|
97c92f712e | ||
|
|
7d37137d4e | ||
|
|
a94479e854 | ||
|
|
f445c23a41 | ||
|
|
c9e2ab3d4f | ||
|
|
862312d185 | ||
|
|
9263515e07 | ||
|
|
d5b669c94b | ||
|
|
281e2d38e3 | ||
|
|
0345181b76 | ||
|
|
ddd710bad1 | ||
|
|
34d58cddc3 | ||
|
|
c66ec1fff7 | ||
|
|
de8dc5b667 | ||
|
|
545b54b4c7 | ||
|
|
e13435712d | ||
|
|
c514c25061 | ||
|
|
ab0ce6b989 | ||
|
|
7af411f637 | ||
|
|
2aa8df2d40 | ||
|
|
c78fcdb719 | ||
|
|
1e465327a6 | ||
|
|
226643ab4a | ||
|
|
651b4b3ba7 | ||
|
|
0314a04b79 | ||
|
|
7cc80df960 | ||
|
|
cc24b3e8fd | ||
|
|
626b3d3039 | ||
|
|
d42146a5cc | ||
|
|
ef42a6393a | ||
|
|
caea5fe61b | ||
|
|
463b3c5b76 | ||
|
|
2592095655 | ||
|
|
d00a333dca | ||
|
|
1dc6509af2 | ||
|
|
7c353a791b | ||
|
|
1e086f7268 | ||
|
|
6457b9560b | ||
|
|
77fc957f64 | ||
|
|
35c2daff59 | ||
|
|
00220b8b3d | ||
|
|
7d614d6ade | ||
|
|
5567187e2c | ||
|
|
e9737cd2ed | ||
|
|
fea5dc907b | ||
|
|
54f4f0a925 | ||
|
|
f33399738b | ||
|
|
f2f139cc0b | ||
|
|
192935e9a9 | ||
|
|
555922492a | ||
|
|
087c8bdc57 | ||
|
|
4876fb6bf5 | ||
|
|
fe995572a8 | ||
|
|
2750630335 | ||
|
|
40d5102b6c | ||
|
|
f2eab87e1e | ||
|
|
baeb525e0a | ||
|
|
0db405f36d | ||
|
|
5b8123914b | ||
|
|
4469de8ed1 | ||
|
|
dd268b68b4 | ||
|
|
871029324b | ||
|
|
cbfd89ca02 | ||
|
|
5d280748aa | ||
|
|
59991b92f1 | ||
|
|
5108678fcd | ||
|
|
2bf8e3f535 | ||
|
|
66f9e38113 | ||
|
|
944567bf66 | ||
|
|
97691de98b | ||
|
|
4ef63cdaea | ||
|
|
d8832134d2 | ||
|
|
679ce613e9 | ||
|
|
04149f328e | ||
|
|
33b15ed01a | ||
|
|
39119e1ada | ||
|
|
36ccfe6f97 | ||
|
|
ab93cfefa0 | ||
|
|
0449c9f331 | ||
|
|
0f21e4a367 | ||
|
|
2a5dc99044 | ||
|
|
ddc59de759 | ||
|
|
a03186a587 | ||
|
|
b44510f03a | ||
|
|
bf7f5ac279 | ||
|
|
a769cc45bf | ||
|
|
2e7ea9a523 | ||
|
|
651a5f5f1b | ||
|
|
bb0718dd2c | ||
|
|
cbe22f74f4 | ||
|
|
4db129cf71 | ||
|
|
b15c5226e4 | ||
|
|
26e02b6689 | ||
|
|
ab65999447 | ||
|
|
09d0386b52 | ||
|
|
dbb30f743f | ||
|
|
0c690061b3 | ||
|
|
fe14fd11f4 | ||
|
|
e3ab981ca2 | ||
|
|
47cd66ba27 | ||
|
|
54cecf41e9 | ||
|
|
e34bca8ce2 | ||
|
|
75374c5e26 | ||
|
|
9fd02fcbdb | ||
|
|
7bc64364c4 | ||
|
|
83b86f355f | ||
|
|
5defb0b9aa | ||
|
|
dd1196b169 | ||
|
|
a5be75a764 | ||
|
|
e9b080e13a | ||
|
|
31739ec27c | ||
|
|
fe9baee372 | ||
|
|
233e05111a | ||
|
|
c1b3b9f43c | ||
|
|
264b7cbba1 | ||
|
|
19320b2f5d | ||
|
|
fc58f416e4 | ||
|
|
f382b0d3de | ||
|
|
6b59220f90 | ||
|
|
7ac81eae59 | ||
|
|
ff1e465100 | ||
|
|
65c40f83aa | ||
|
|
b59ed5e96e | ||
|
|
1d3b1f73e4 | ||
|
|
fc5cc52e75 | ||
|
|
0795da732f | ||
|
|
4724283d0f | ||
|
|
2d5c2002de | ||
|
|
aed7dd024e | ||
|
|
90d340911f | ||
|
|
15b6ab6873 | ||
|
|
29e74f51f2 | ||
|
|
d717a5cac9 | ||
|
|
edf943cf0e | ||
|
|
5b8c6f2943 | ||
|
|
d7fa8f5383 | ||
|
|
d4dfbdea81 | ||
|
|
0da41a00c6 | ||
|
|
50cda3bfbf | ||
|
|
0c11d07cae | ||
|
|
e6d0e47e87 | ||
|
|
8084852ab9 | ||
|
|
cef2864905 | ||
|
|
59e398620b | ||
|
|
69860ac7b5 | ||
|
|
39120c6a25 | ||
|
|
b56689fd89 | ||
|
|
ab2e0bf933 | ||
|
|
d8e233941c | ||
|
|
866dda88bf | ||
|
|
4e9f170142 | ||
|
|
9072c238a6 | ||
|
|
ca46cd0363 | ||
|
|
054336e637 | ||
|
|
6998494800 | ||
|
|
b5dfa18949 | ||
|
|
2e97e6e8b2 | ||
|
|
793a6b8ddd | ||
|
|
a1b292bb31 | ||
|
|
d73d657cda | ||
|
|
49502c8c8f | ||
|
|
b40407e35f | ||
|
|
9b725a856f | ||
|
|
2cd2db28d9 | ||
|
|
424f2857dd | ||
|
|
c49bd8f512 | ||
|
|
209aebc700 | ||
|
|
b154fa4b9f | ||
|
|
2920f5b1c2 | ||
|
|
667df74333 | ||
|
|
fb97ca7100 | ||
|
|
4cb312287f | ||
|
|
ef6c8451b9 | ||
|
|
a4c50516b0 | ||
|
|
ff77dabbbe | ||
|
|
6e10227a94 | ||
|
|
0ba5b155a3 | ||
|
|
7f958dfb8d | ||
|
|
6c40cad879 | ||
|
|
af6b40a9a3 | ||
|
|
d0ac9f9e08 | ||
|
|
ac37584270 | ||
|
|
e22d8cceaa | ||
|
|
12a028160f | ||
|
|
4f0b3578a1 | ||
|
|
a1ebb548cf | ||
|
|
dd600df3dd | ||
|
|
0a68486a3f | ||
|
|
7e2a7c05a9 | ||
|
|
c878bff7a6 | ||
|
|
6fc0921238 | ||
|
|
5fa1bbbc38 | ||
|
|
2210242923 | ||
|
|
a4bdacd9d8 | ||
|
|
8e08cbe221 | ||
|
|
62ca83b92b | ||
|
|
f9960dbbab | ||
|
|
08c6364ff4 | ||
|
|
cc05bda4ab | ||
|
|
3cf48f19f4 | ||
|
|
6be896c8f1 | ||
|
|
d37d6f69f4 | ||
|
|
f865bb9fe7 | ||
|
|
acbf5fe28f | ||
|
|
c7dbf19b40 | ||
|
|
29b3ecd25f | ||
|
|
7bf1499039 | ||
|
|
84ef2d4d11 | ||
|
|
326f3217ab | ||
|
|
5931ae29dc | ||
|
|
73ac4e384e | ||
|
|
9ff9f7b8d8 | ||
|
|
2dfcf65526 | ||
|
|
e22032fdc5 | ||
|
|
5c7f912c6a | ||
|
|
968dd67796 | ||
|
|
58acdb913b | ||
|
|
57e3d1220b | ||
|
|
899b98d409 | ||
|
|
d505985c25 | ||
|
|
94dc3255b1 | ||
|
|
d88cb410b7 | ||
|
|
88bd7de0b1 | ||
|
|
81d26fa096 | ||
|
|
d04e2e9211 | ||
|
|
9a23e968ed | ||
|
|
9e9f998bed | ||
|
|
4c39e6fe41 | ||
|
|
82116f4994 | ||
|
|
28157a0fd8 | ||
|
|
e006705fbf | ||
|
|
9d0a8037f7 | ||
|
|
a8b3ef51ed | ||
|
|
bac0ae9da3 | ||
|
|
cc56ae65dd | ||
|
|
b7fa7592f8 | ||
|
|
744ee3ad52 | ||
|
|
3194915d0a | ||
|
|
f31ee74fc5 | ||
|
|
cc290b34a0 | ||
|
|
b2b5e94344 | ||
|
|
341918027a | ||
|
|
53235c19b8 | ||
|
|
6bc575ba9e | ||
|
|
dccb2a8b8a | ||
|
|
2ab83deae0 | ||
|
|
1f5e73692b | ||
|
|
9f7d9364eb | ||
|
|
92145d4a79 | ||
|
|
97a78aaf10 | ||
|
|
140c755977 | ||
|
|
14e1de6194 | ||
|
|
69b6c1f47a | ||
|
|
d3f957e21f | ||
|
|
8d81d29aa1 | ||
|
|
58ed5b639e | ||
|
|
3c15d645b1 | ||
|
|
af72287f31 | ||
|
|
8d1bad1378 | ||
|
|
2b0022e768 | ||
|
|
4bb0faaf55 | ||
|
|
58d0332d59 | ||
|
|
2093a1d946 | ||
|
|
08e3986b57 | ||
|
|
392e60cc99 | ||
|
|
90e8732746 | ||
|
|
0365786fe4 | ||
|
|
12469b7c72 | ||
|
|
8f7b9d31f4 | ||
|
|
05ef6a33de | ||
|
|
10772303fd | ||
|
|
ec4685f419 | ||
|
|
6c02d0d213 | ||
|
|
fb0d4e37df | ||
|
|
ed8602e247 | ||
|
|
451259712d | ||
|
|
ba5bff1461 | ||
|
|
a9c2a815d0 | ||
|
|
0eca1bf583 | ||
|
|
44787913e2 | ||
|
|
0ba5f8deb7 | ||
|
|
a6e2924411 | ||
|
|
cfef5ca890 | ||
|
|
46188cca28 | ||
|
|
9eace2894a | ||
|
|
eb7d986502 | ||
|
|
a44521c1cd | ||
|
|
b5d27d7f6d | ||
|
|
eb781c5f72 | ||
|
|
e50514b4b6 | ||
|
|
273b5e53cb | ||
|
|
0208a5c68f | ||
|
|
c15756c0f8 | ||
|
|
38e43b85fe | ||
|
|
91580be26d | ||
|
|
0caf120b86 | ||
|
|
021b6ff4c9 | ||
|
|
029ff4d95e | ||
|
|
c318e2f6ca | ||
|
|
8eaf33bfd4 | ||
|
|
8c6213b6b5 | ||
|
|
4f7b72aaa3 | ||
|
|
b0fcc3e5b6 | ||
|
|
ae42a03152 | ||
|
|
5f58e12b6d | ||
|
|
a7e08a2e2a | ||
|
|
d5b57c5890 | ||
|
|
62424b9629 | ||
|
|
6b3eabf743 | ||
|
|
71e9acf5a6 | ||
|
|
df39bcf5da | ||
|
|
b9e81da3fb | ||
|
|
57c656ce54 | ||
|
|
4da4737655 | ||
|
|
56ebe80f2c | ||
|
|
75608ad194 | ||
|
|
2c0f0a415a | ||
|
|
fc4f8bae50 | ||
|
|
579686b7d7 | ||
|
|
15daf83022 | ||
|
|
6c29f89fae | ||
|
|
4b3453a55e | ||
|
|
cd741b08fc | ||
|
|
54ae1ed869 | ||
|
|
535ad269a5 | ||
|
|
d1969b0bef | ||
|
|
f350f324fa | ||
|
|
8c20f88dd6 | ||
|
|
83bd04003a | ||
|
|
006ad3a33c | ||
|
|
8bca388927 | ||
|
|
08ad999f07 | ||
|
|
21d6a0a936 | ||
|
|
8c7c5af21a | ||
|
|
c1fdc1ef44 | ||
|
|
801c3a1422 | ||
|
|
764f21008f | ||
|
|
fa668aee72 | ||
|
|
87d41e5622 | ||
|
|
a17cb6d151 | ||
|
|
0fe46680f1 | ||
|
|
5281bcf441 | ||
|
|
b63cb736be | ||
|
|
8c13506a8d | ||
|
|
4cd5c0daa0 | ||
|
|
458d278e2b | ||
|
|
a3bf2f0830 | ||
|
|
b492526d13 | ||
|
|
58e825e192 | ||
|
|
53c4e37131 | ||
|
|
e117dd7637 | ||
|
|
9406461c89 | ||
|
|
44d9dc2b7a | ||
|
|
3688f1e14c | ||
|
|
1273c73366 | ||
|
|
6e9201945f | ||
|
|
a947b16247 | ||
|
|
70db8e4c85 | ||
|
|
371621cffb | ||
|
|
103d769278 | ||
|
|
bb1f976bcd | ||
|
|
03bc5847c7 | ||
|
|
01c2a40996 | ||
|
|
853347952f | ||
|
|
90a1b864ee | ||
|
|
4fdd23a32e | ||
|
|
179995b95b | ||
|
|
dd04f05ed5 | ||
|
|
7546d23ab9 | ||
|
|
b0397d0d71 | ||
|
|
f2a9d8a160 | ||
|
|
a806c41ba3 | ||
|
|
adf6002035 | ||
|
|
34a1714a58 | ||
|
|
f627764679 | ||
|
|
545469ea53 | ||
|
|
ef8ebf1440 | ||
|
|
33dcea6aa5 | ||
|
|
a334211f80 | ||
|
|
7a3ee9a2be | ||
|
|
3b0fac78bd | ||
|
|
2d9ff63276 | ||
|
|
a9d95930e8 | ||
|
|
16212b4cc2 | ||
|
|
8721b0f01d | ||
|
|
7646d37ef1 | ||
|
|
b3c79be6c0 | ||
|
|
44ccefc092 | ||
|
|
95a527224d | ||
|
|
25785a7aeb | ||
|
|
50d0930e13 | ||
|
|
8e5e22aba7 | ||
|
|
fbe921023a | ||
|
|
45c25de1f8 | ||
|
|
11ca323f97 | ||
|
|
26a8bcfb8d | ||
|
|
988493a4ae | ||
|
|
720c036014 | ||
|
|
b082fe48d5 | ||
|
|
dabff33228 | ||
|
|
86b27aef19 | ||
|
|
6ebee3b495 | ||
|
|
a1d157efc6 | ||
|
|
30260ca8e7 | ||
|
|
e4df2e1d58 | ||
|
|
1ad622100f | ||
|
|
9d4b82e7b2 | ||
|
|
7c75d4cd21 | ||
|
|
4fc6d6e73d | ||
|
|
158595b208 | ||
|
|
71e90ba21c | ||
|
|
596c778d27 | ||
|
|
d9684673fa | ||
|
|
6589e2e2db | ||
|
|
7d23a1ecbb | ||
|
|
14d6cc7286 | ||
|
|
5c38a43e17 | ||
|
|
0f0d4b1fa4 | ||
|
|
0cff4d0e71 | ||
|
|
d9a86af8ea | ||
|
|
f675fc1252 | ||
|
|
0b8bdee7d3 | ||
|
|
0ff6037772 | ||
|
|
4f92c808cf | ||
|
|
3c4cb647fb | ||
|
|
a3514174d2 | ||
|
|
07447b1fc5 | ||
|
|
4d98ce5fa5 | ||
|
|
85fc2173cc | ||
|
|
f0fe7757c6 | ||
|
|
fabf440d6c | ||
|
|
3dd8d1cf40 | ||
|
|
4b0b8f6228 | ||
|
|
6a818e57d5 | ||
|
|
9da93a1d2b | ||
|
|
30b9507f62 | ||
|
|
b5f5a11e4f | ||
|
|
c910cb9ca1 | ||
|
|
3b76c83ff0 | ||
|
|
7b9fefb691 | ||
|
|
b116bcbc24 | ||
|
|
88d1906ff7 | ||
|
|
5ae08cd2bf | ||
|
|
4c92b4bf08 | ||
|
|
ebf61935c5 | ||
|
|
9e5f1fc97d | ||
|
|
fa56cdd906 | ||
|
|
bf5785d035 | ||
|
|
23b51e2526 | ||
|
|
38e8f1d2ff | ||
|
|
ca2c4c55fd | ||
|
|
11419c04a7 | ||
|
|
42f953ad12 | ||
|
|
3779649a53 | ||
|
|
9184397ef7 | ||
|
|
f858524e90 | ||
|
|
d1f2070f22 | ||
|
|
48442bd89b | ||
|
|
9d71033768 | ||
|
|
ba9eeaa271 | ||
|
|
a70a30805e | ||
|
|
ad5d0d78d0 | ||
|
|
3b7944d777 | ||
|
|
31c6ce4ebc | ||
|
|
6966f6586c | ||
|
|
9b496d5477 | ||
|
|
44d4a33db4 | ||
|
|
d6a1744fe0 | ||
|
|
26b3f264ac | ||
|
|
552786170a | ||
|
|
da19710f77 | ||
|
|
960bbddf67 | ||
|
|
4ec11dcaac | ||
|
|
bf6c7556c8 | ||
|
|
38fc4ac293 | ||
|
|
0950464770 | ||
|
|
a9abd596f4 | ||
|
|
9c00856e6f | ||
|
|
2c23bb6566 | ||
|
|
5c45e01a6f | ||
|
|
9024db9e45 | ||
|
|
e76a12ed76 | ||
|
|
0a496230a4 | ||
|
|
f77cea49de | ||
|
|
2463fed6bc | ||
|
|
4ebb67930e | ||
|
|
aae1163ab0 | ||
|
|
20ac2ba2c5 | ||
|
|
ebc7a9ac9f | ||
|
|
da3000aa58 | ||
|
|
cc8a28ef83 | ||
|
|
f41c7fb3ae | ||
|
|
7bdc0856dc | ||
|
|
bf9b3eb667 | ||
|
|
e9f2b9999b | ||
|
|
fd32d4271d | ||
|
|
ba0366975d | ||
|
|
a29051f2a8 | ||
|
|
044b8e1b5c | ||
|
|
db37900654 | ||
|
|
f783ed921d | ||
|
|
b40ad96472 | ||
|
|
18def1e965 | ||
|
|
cddf1c17d3 | ||
|
|
f0370f479b | ||
|
|
571dc274bb | ||
|
|
5c6439d2e2 | ||
|
|
a2db4a8b50 | ||
|
|
50c17231fb | ||
|
|
c5ddc899c7 | ||
|
|
d5a8ad0e87 | ||
|
|
25a492ca14 | ||
|
|
b2c9885b83 | ||
|
|
434a22bfae | ||
|
|
5134a254e2 | ||
|
|
1ccb8e2aa2 | ||
|
|
2bf468c8a0 | ||
|
|
a430e96cff | ||
|
|
195e9d1983 | ||
|
|
a404df913e | ||
|
|
0cb43d15fa | ||
|
|
2c8fc48369 | ||
|
|
75e36d3a38 | ||
|
|
ac92184766 | ||
|
|
05ea165960 | ||
|
|
8babd0b097 | ||
|
|
a282d5f74e | ||
|
|
e6b8fcd33a | ||
|
|
03fde8ecde | ||
|
|
33022cdf20 | ||
|
|
41ec3574be | ||
|
|
f8b23ccdc0 | ||
|
|
71df0f78b4 | ||
|
|
13af90d93c | ||
|
|
52f784fb56 | ||
|
|
26e3f7a751 | ||
|
|
e95fbe2d60 | ||
|
|
b26f76ed3b | ||
|
|
f2d00ea6fd | ||
|
|
b7514e907f | ||
|
|
156231126f | ||
|
|
3e89ee1969 | ||
|
|
74d51b5d97 | ||
|
|
b1806c5e5a | ||
|
|
4672ce6d94 | ||
|
|
926a22037b | ||
|
|
287927b7ac | ||
|
|
607eac48b3 | ||
|
|
3e40d142f8 | ||
|
|
ebb49c3d79 | ||
|
|
8d48d8eeed | ||
|
|
c97cb1c0d0 | ||
|
|
a4f43d5219 | ||
|
|
c456a14c9a | ||
|
|
d1f061f380 | ||
|
|
4acb626840 | ||
|
|
28345e5cf6 | ||
|
|
c838754021 | ||
|
|
3acdac0148 | ||
|
|
b75e95a4ef | ||
|
|
16840a4e83 | ||
|
|
1978818cf7 | ||
|
|
5ce88603df | ||
|
|
89539fa451 | ||
|
|
49ca2cbb8b | ||
|
|
9150f2e06c | ||
|
|
1a15ea4f31 | ||
|
|
e40d14b40a | ||
|
|
4ee9b51030 | ||
|
|
2859b3921a | ||
|
|
32afc0e9f9 | ||
|
|
54374eeeb6 | ||
|
|
ceaa4cf9f8 | ||
|
|
a264fb65b5 | ||
|
|
be6b1cc7ff | ||
|
|
38d375401f | ||
|
|
e210343ec0 | ||
|
|
d68340e71c | ||
|
|
310218d1cd | ||
|
|
390594394b | ||
|
|
c550c43fff | ||
|
|
05f256fb4c | ||
|
|
5e10da4a6a | ||
|
|
4590e0e55e | ||
|
|
22a4ef930b | ||
|
|
0379ada7ad | ||
|
|
f9269a9aca | ||
|
|
5191ba299c | ||
|
|
c5d4740476 | ||
|
|
c3ff604997 | ||
|
|
d541e64f7f | ||
|
|
068ffbc391 | ||
|
|
6a2a94ed72 | ||
|
|
07d02ed496 | ||
|
|
4625a80676 | ||
|
|
641221f9c0 | ||
|
|
e12ef40218 | ||
|
|
2ddfdff471 | ||
|
|
f3aff5704c | ||
|
|
7768504a93 | ||
|
|
ce0e423e9f | ||
|
|
58b6c40aaf | ||
|
|
6b73c84ee1 | ||
|
|
448fdf4a58 | ||
|
|
8a75c997c8 | ||
|
|
aa69b0ed21 | ||
|
|
9332516a7f | ||
|
|
da56e17b75 | ||
|
|
78351e80ad | ||
|
|
9953833a05 | ||
|
|
d2c715a752 | ||
|
|
4e23e8da1e | ||
|
|
df07a36d88 | ||
|
|
64cdfc8c51 | ||
|
|
fa1d129a2d | ||
|
|
94af67cf03 | ||
|
|
e2b1f05f4b | ||
|
|
03cf2ee6f0 | ||
|
|
6f220b0d0b | ||
|
|
548a7a386d | ||
|
|
737b777683 | ||
|
|
e5ec23354d | ||
|
|
bad23f9779 | ||
|
|
16753f7a42 | ||
|
|
7e4845e2ef | ||
|
|
c2e6bb1bba | ||
|
|
d576d630d8 | ||
|
|
ae7648fe0a | ||
|
|
919d699385 | ||
|
|
a943caaf4a | ||
|
|
f6d19729f3 | ||
|
|
3506d29d82 | ||
|
|
e1dc6e8e25 | ||
|
|
dacaa278f9 | ||
|
|
812f7dce16 | ||
|
|
2c07fd4d02 | ||
|
|
c9c08fd077 | ||
|
|
2346a0a88c | ||
|
|
f285dbdf43 | ||
|
|
0b27a93069 | ||
|
|
743ba6d408 | ||
|
|
0a7fb3243e | ||
|
|
e7151506f1 | ||
|
|
f5a2c69481 | ||
|
|
9352716e2d | ||
|
|
568316e2db | ||
|
|
6aaceb7d35 | ||
|
|
927c3eee0f | ||
|
|
80fcb8c31a | ||
|
|
b85653d55d | ||
|
|
67a513a488 | ||
|
|
929946d753 | ||
|
|
04a3b0a092 | ||
|
|
ea8f852fc5 | ||
|
|
ccd99fa45e | ||
|
|
36d634824c | ||
|
|
1a7833a0e3 | ||
|
|
88c579f2d1 | ||
|
|
fa71baa4d7 | ||
|
|
6b94b30af4 | ||
|
|
66b5ddcfd8 | ||
|
|
b0513b7a66 | ||
|
|
e97129f991 | ||
|
|
cc59120347 | ||
|
|
f431230f7d | ||
|
|
83639826d6 | ||
|
|
70ab911d0b | ||
|
|
3e17d769b9 | ||
|
|
086f4ceacb | ||
|
|
50cbf84293 | ||
|
|
404618c7c5 | ||
|
|
3cc595c2b7 | ||
|
|
e9b8cb06bf | ||
|
|
25074fb608 | ||
|
|
f295a15614 | ||
|
|
558b077fd8 | ||
|
|
afca9aeba9 | ||
|
|
8e485ab09a | ||
|
|
84e71248e2 | ||
|
|
ff0b9c8ab6 | ||
|
|
a71decee90 | ||
|
|
73ac1d53ec | ||
|
|
612cfe1058 | ||
|
|
7844122141 | ||
|
|
f860afc981 | ||
|
|
31ecc93082 | ||
|
|
fd70e803a0 | ||
|
|
babdd65d68 | ||
|
|
8d8876cafc | ||
|
|
81fd8811a0 | ||
|
|
c3cd93397e | ||
|
|
2028c4652e | ||
|
|
a2169cd8f2 | ||
|
|
e51a262554 | ||
|
|
0b3bf6705c | ||
|
|
0f04dda084 | ||
|
|
0d87bd16bd | ||
|
|
b3702e14a3 | ||
|
|
14a37445df | ||
|
|
390bc72f85 | ||
|
|
f1e69ba5dc | ||
|
|
4ca0a9fcb0 | ||
|
|
9c2934c25d | ||
|
|
e3a1bdee64 | ||
|
|
bdfe2ec9cf | ||
|
|
ff974411bb | ||
|
|
f5f3c78f28 | ||
|
|
fe90dbc022 | ||
|
|
4ffc5effc8 | ||
|
|
c2a77056f3 | ||
|
|
d26ae9524b | ||
|
|
20bdcdb730 | ||
|
|
0fe5503e58 | ||
|
|
e93ffe54b0 | ||
|
|
2b4351612b | ||
|
|
46f14c974d | ||
|
|
634ffd0111 | ||
|
|
3cbeef9506 | ||
|
|
a4d2bc520b | ||
|
|
49d1c86cbc | ||
|
|
a474dcaeae | ||
|
|
8d664a267e | ||
|
|
92361b4669 | ||
|
|
f66169c2d2 | ||
|
|
d3a832bd33 | ||
|
|
fa9f197afd | ||
|
|
ea22ca0f3c | ||
|
|
3897571520 | ||
|
|
6ac0b14a21 | ||
|
|
466770c802 | ||
|
|
3ca38fbe2e | ||
|
|
14a0e523e3 | ||
|
|
042b9384b2 | ||
|
|
ef128982bf | ||
|
|
791300c5a6 | ||
|
|
325abcee85 | ||
|
|
02159e48b4 | ||
|
|
d05287f87c | ||
|
|
9b12f58b23 | ||
|
|
e0fbecfcfb | ||
|
|
1af2760ded | ||
|
|
2f20b3e612 | ||
|
|
52ceb5a624 | ||
|
|
0de84449fb | ||
|
|
4b299df52a | ||
|
|
ce33e1442d | ||
|
|
364db71364 | ||
|
|
42ffe00f42 | ||
|
|
3c35dfc730 | ||
|
|
244f5ec0ef | ||
|
|
eacc6e770e | ||
|
|
d6878e6125 | ||
|
|
636e36857b | ||
|
|
604c4ed430 | ||
|
|
d039590255 | ||
|
|
1aca6f8dcd | ||
|
|
a8a5248bb7 | ||
|
|
3690e264bf | ||
|
|
1f60decc07 | ||
|
|
39b85e29b6 | ||
|
|
268c23ac82 | ||
|
|
a16943c363 | ||
|
|
355e158dba | ||
|
|
ee37544370 | ||
|
|
9786adbeb6 | ||
|
|
cab9f5b253 | ||
|
|
9ef488cd07 | ||
|
|
5561b16f80 | ||
|
|
63250e1881 | ||
|
|
3a976aed0f | ||
|
|
dddf857632 | ||
|
|
9a95fd3684 | ||
|
|
0846e8f43b | ||
|
|
3ecbfced88 | ||
|
|
37b4c2f476 | ||
|
|
8322750e2a | ||
|
|
976f28b326 | ||
|
|
d5390e7556 | ||
|
|
ca4b91fbbe | ||
|
|
722e8f761f | ||
|
|
b88bd1732f | ||
|
|
81af204fa5 | ||
|
|
4616d80802 | ||
|
|
2a064b7738 | ||
|
|
95da8a6b2e | ||
|
|
dee27422e1 | ||
|
|
14ca6ec8e2 | ||
|
|
3959d9aaf9 | ||
|
|
acfefb688c | ||
|
|
21dfb2ee1b | ||
|
|
5b015de6f0 | ||
|
|
f5b16597a6 | ||
|
|
649d97e9de | ||
|
|
6ab75b5c09 | ||
|
|
dd114de7e3 | ||
|
|
cf872fd6c7 | ||
|
|
97eeb04ecb | ||
|
|
9182f23c4f | ||
|
|
8c9cb07b55 | ||
|
|
1fff73bd82 | ||
|
|
2e6ee2845b | ||
|
|
ba080af7ec | ||
|
|
0570864f72 | ||
|
|
c157dab6d0 | ||
|
|
390560a78f | ||
|
|
babbf408ce | ||
|
|
5a17ea0662 | ||
|
|
faa60da6c5 | ||
|
|
a70cb3cc78 | ||
|
|
e4172993f1 | ||
|
|
93b5b5b7d7 | ||
|
|
a304524caa | ||
|
|
adae10f8e1 | ||
|
|
f9f338fb00 | ||
|
|
b29fbd2567 | ||
|
|
7e4969064c | ||
|
|
17e744b5e0 | ||
|
|
0008704904 | ||
|
|
838514ccf8 | ||
|
|
dcebb77bfe | ||
|
|
886b18be3b | ||
|
|
0b707bc8b8 | ||
|
|
89cb15bcbe | ||
|
|
cd47424718 | ||
|
|
fea41392c0 | ||
|
|
7774835cde | ||
|
|
e35c517640 | ||
|
|
6f94216107 | ||
|
|
3efc7c62b0 | ||
|
|
222cef0714 | ||
|
|
4e6540b3f7 | ||
|
|
c70b1ec0d3 | ||
|
|
744894ca09 | ||
|
|
9c1df5f89e | ||
|
|
ef8f1c778a | ||
|
|
f1d053651b | ||
|
|
12b89fa9f0 | ||
|
|
373f74dc7f | ||
|
|
6e3fa51042 | ||
|
|
bb7e5e5850 | ||
|
|
c26539a88d | ||
|
|
10d25e95af | ||
|
|
08f8310e09 | ||
|
|
10f0200f66 | ||
|
|
eb73f30c5a | ||
|
|
6286e0403f | ||
|
|
7ffc4a2861 | ||
|
|
7ef8432c5a | ||
|
|
e0b6e7d44d | ||
|
|
c0cb7d8e25 | ||
|
|
4b3e917320 | ||
|
|
6fb5990a90 | ||
|
|
7028a6659f | ||
|
|
996d8fc8e8 | ||
|
|
cd1307122a | ||
|
|
d4808e1417 | ||
|
|
e82a5c3c14 | ||
|
|
a962d0f39b | ||
|
|
8db18e8f62 | ||
|
|
c98d8e1ed4 | ||
|
|
0a2b1c0ee5 | ||
|
|
9b99c5603b | ||
|
|
b9f037d109 | ||
|
|
595e913007 | ||
|
|
4f8fe87ee6 | ||
|
|
28e8984b72 | ||
|
|
b8bd81f18f | ||
|
|
e91938cdf2 | ||
|
|
01912378ff | ||
|
|
c1ce4d054d | ||
|
|
776e96cecd | ||
|
|
a58f200d8a | ||
|
|
fe9fb2fb9d | ||
|
|
aaa3fa1467 | ||
|
|
2b29ce2298 | ||
|
|
050f15f772 | ||
|
|
d305dcf18b | ||
|
|
65819423ce | ||
|
|
bf2896177c | ||
|
|
302745f3fc | ||
|
|
4cb51452f8 | ||
|
|
04f0a3c6d1 | ||
|
|
2744d4f25d | ||
|
|
88cc8c91ff | ||
|
|
ca26a52b10 | ||
|
|
c5d939084e | ||
|
|
0b60a0659a | ||
|
|
13c621b5e8 | ||
|
|
a4d2164f4a | ||
|
|
b98afd7c70 | ||
|
|
00fed9521a | ||
|
|
d646cd1209 | ||
|
|
be64cfc96b | ||
|
|
a3cbfd56f3 | ||
|
|
af63a7a349 | ||
|
|
79962c56cd | ||
|
|
cda1118bf8 | ||
|
|
0a5dadfe82 | ||
|
|
42604d1423 | ||
|
|
1448010401 | ||
|
|
bac6e5ea24 | ||
|
|
96ffa24a89 | ||
|
|
8e68139bd4 | ||
|
|
7cc92f5e10 | ||
|
|
a6f865db15 | ||
|
|
2b111a8ba6 | ||
|
|
1cb464b8b8 | ||
|
|
bcf83eb1c4 | ||
|
|
aa4e16a912 | ||
|
|
1e38c979eb | ||
|
|
85412f3759 | ||
|
|
c6226c137e | ||
|
|
cceb8396d3 | ||
|
|
1dc34bca77 | ||
|
|
c4323d1dc3 | ||
|
|
9d5b1173f8 | ||
|
|
5d6bd5f65f | ||
|
|
fafba34a5c | ||
|
|
086acdc527 | ||
|
|
ed6d0225e4 | ||
|
|
95c1a91b24 | ||
|
|
67668218c8 | ||
|
|
3ce78f0ae5 | ||
|
|
fbefe2f917 | ||
|
|
36183c5310 | ||
|
|
c38ac1ab87 | ||
|
|
2ac6df159e | ||
|
|
1e851471d7 | ||
|
|
fba38acb21 | ||
|
|
a277584532 | ||
|
|
35afcd8650 | ||
|
|
9334204e0f | ||
|
|
3926ec04ab | ||
|
|
6f2d531f03 | ||
|
|
54037a42c5 | ||
|
|
7795cbe549 | ||
|
|
ebdabbcaee | ||
|
|
9e8d7bc6dd | ||
|
|
eb533b6430 | ||
|
|
cd0de149ae | ||
|
|
7aa9ca2b6a | ||
|
|
74e032ef1f | ||
|
|
6ac1c9b938 | ||
|
|
f68e907ee4 | ||
|
|
18dbc71683 | ||
|
|
a5d5091e31 | ||
|
|
cbc4ae9918 | ||
|
|
5844159c7b | ||
|
|
a2464a4fa5 | ||
|
|
efdbabf464 | ||
|
|
921d6885b1 | ||
|
|
fe62ccb08d | ||
|
|
47a9fdaaf1 | ||
|
|
d54cf69538 | ||
|
|
02bd21e69e | ||
|
|
5a8c037956 | ||
|
|
718f51e581 | ||
|
|
57cc3be42b | ||
|
|
9ff66cb703 | ||
|
|
0e5807f791 | ||
|
|
d2568b0659 | ||
|
|
28e8e8778b | ||
|
|
1f679b93c5 | ||
|
|
0f09afdd84 | ||
|
|
a41d9f0a24 | ||
|
|
28c097f31b | ||
|
|
02974a16b0 | ||
|
|
b2aa988b11 | ||
|
|
293b38b458 | ||
|
|
729ee1f314 | ||
|
|
444bd51224 | ||
|
|
74f80f9c80 | ||
|
|
13b8bcce1a | ||
|
|
9709fe4c0c | ||
|
|
82bad462cd | ||
|
|
a67cf334a5 | ||
|
|
13498986a1 | ||
|
|
fabbe9ed5f | ||
|
|
871ef07410 | ||
|
|
f2546a2006 | ||
|
|
9be5dcca61 | ||
|
|
b8e7db1e01 | ||
|
|
1d23e4485e | ||
|
|
1a8129513d | ||
|
|
a20ee91475 | ||
|
|
99d8085d66 | ||
|
|
3f3875fcfd | ||
|
|
eaf39ba279 | ||
|
|
806e8160f0 | ||
|
|
ad172c3e1f | ||
|
|
8d4d176582 | ||
|
|
dadec39ed9 | ||
|
|
b7131f8b03 | ||
|
|
bef927cf4a | ||
|
|
bdf7c5c339 | ||
|
|
8633baee89 | ||
|
|
d9c4ee208e | ||
|
|
13d5cde23c | ||
|
|
1c11a30ce1 | ||
|
|
6587649fb6 | ||
|
|
641785930e | ||
|
|
bef33e9a40 | ||
|
|
b158ce86b2 | ||
|
|
52fc2ed2c2 | ||
|
|
11673c2e59 | ||
|
|
78599e150a | ||
|
|
9b082e6d5a | ||
|
|
5273c6186c | ||
|
|
361d0c4300 | ||
|
|
1f3954fc37 | ||
|
|
f111bf8da1 | ||
|
|
87cf5beec5 | ||
|
|
0794791516 | ||
|
|
114ef74a6d | ||
|
|
f8dfcefb0b | ||
|
|
5a62a2d8df | ||
|
|
bcb2d9088f | ||
|
|
c0699bb7b1 | ||
|
|
c04ac84cf4 | ||
|
|
653b210c36 | ||
|
|
744b87b988 | ||
|
|
a0b2cc8722 | ||
|
|
35469909a3 | ||
|
|
5ba01b436c | ||
|
|
a398ae906e | ||
|
|
de0b30db39 | ||
|
|
9bdc09f5b4 | ||
|
|
95241983c5 | ||
|
|
786323bab7 | ||
|
|
7b827ec6d2 | ||
|
|
07768e86c9 | ||
|
|
dca1b4f2b1 | ||
|
|
d9d3418f13 | ||
|
|
26f9afe52c | ||
|
|
9e5d2b3d1c | ||
|
|
1ad9eea353 | ||
|
|
2fce49e119 | ||
|
|
9af2a750ea | ||
|
|
57785c5d68 | ||
|
|
fb6fa7321b | ||
|
|
f482b7e681 | ||
|
|
5bdcf0067b | ||
|
|
7056216262 | ||
|
|
80149f3b95 | ||
|
|
3170725aec | ||
|
|
5bd25f4545 | ||
|
|
5bde69d625 | ||
|
|
919545a674 | ||
|
|
8f6138bc82 | ||
|
|
acf56ca878 | ||
|
|
029e141135 | ||
|
|
56af03984b | ||
|
|
212f6f2494 | ||
|
|
2b7e8b3dfd | ||
|
|
8581d89f9a | ||
|
|
8a1d0dda76 | ||
|
|
2d394a2deb | ||
|
|
249d1a3e58 | ||
|
|
959564cc60 | ||
|
|
124ff779dd | ||
|
|
5e7b675797 | ||
|
|
b9d8cbb8ff | ||
|
|
bd545e78b2 | ||
|
|
45ecff07d3 | ||
|
|
8b65bb004f | ||
|
|
2d12b422e5 | ||
|
|
3d3b891371 | ||
|
|
83f9a870bf | ||
|
|
6e8742c806 | ||
|
|
4f7c65be18 | ||
|
|
63ec52d94b | ||
|
|
348214d8bf | ||
|
|
bec6ede79e | ||
|
|
78aed05012 | ||
|
|
a6ebcce453 | ||
|
|
be89a9fb3d | ||
|
|
56cd9e62f7 | ||
|
|
fb29f51fa9 | ||
|
|
d85250553c | ||
|
|
4d89a39ce8 | ||
|
|
ce31ede8f0 | ||
|
|
0f63db8dd0 | ||
|
|
0a8f919179 | ||
|
|
d2d6f5d6b3 | ||
|
|
125c8864fe | ||
|
|
e03183e926 | ||
|
|
8773aea248 | ||
|
|
506328c48a | ||
|
|
fefbf5b254 | ||
|
|
0590734d26 | ||
|
|
67036f7537 | ||
|
|
d21fd37c8d | ||
|
|
5aeef6edc9 | ||
|
|
e20572161f | ||
|
|
4c7fbef54c | ||
|
|
6a21258874 | ||
|
|
6b3e6d55eb | ||
|
|
8c513bdd61 | ||
|
|
34aed240fa | ||
|
|
c83f8c47e9 | ||
|
|
c05ac211db | ||
|
|
652919c4df | ||
|
|
3a373d158a | ||
|
|
dd864f5541 | ||
|
|
21b0f7b626 | ||
|
|
8d4bc3d9c8 | ||
|
|
bf097e934b | ||
|
|
e09dccc3e0 | ||
|
|
b34adc2dda | ||
|
|
59412cb405 | ||
|
|
92ee34c7df | ||
|
|
9d607caeca | ||
|
|
150443adba | ||
|
|
c0c2f589ff | ||
|
|
08423d90ae | ||
|
|
dc85e632db | ||
|
|
f77c35733b | ||
|
|
4e2b9f9c96 | ||
|
|
fbb51e80b2 | ||
|
|
b8880b3692 | ||
|
|
05e7adc71d | ||
|
|
71095200c3 | ||
|
|
d0e64b1a4e | ||
|
|
4d8fbfd272 | ||
|
|
104a9b17f5 | ||
|
|
f5177fe3e9 | ||
|
|
5b20bd5e65 | ||
|
|
f75e68e3fe | ||
|
|
15c6eb7d61 | ||
|
|
34d447ce0d | ||
|
|
55a171a40e | ||
|
|
f0b9aa4c85 | ||
|
|
297e0835e8 | ||
|
|
3a429ec99d | ||
|
|
7c36d1c241 | ||
|
|
de43db22b3 | ||
|
|
4dd3e8d897 | ||
|
|
6c843a4bd5 | ||
|
|
38a9e53338 | ||
|
|
bc129af82b | ||
|
|
8a59c99c03 | ||
|
|
69b615e6a5 | ||
|
|
6d2796fcbd | ||
|
|
c115dad017 | ||
|
|
349eb4d9e2 | ||
|
|
89b5b9f5de | ||
|
|
915917adaa | ||
|
|
734bacbdb3 | ||
|
|
39c3234574 | ||
|
|
bf6e820ee9 | ||
|
|
0207afb434 | ||
|
|
a12836c8fb | ||
|
|
dc7c1bba96 | ||
|
|
a75d2768dc | ||
|
|
98d9abda3b | ||
|
|
2ad0e541eb | ||
|
|
dc57d08c82 | ||
|
|
c259e2c9f8 | ||
|
|
0653065fd6 | ||
|
|
a11765357b | ||
|
|
268d90ca5f | ||
|
|
30f7f803ed | ||
|
|
463c90dfd3 | ||
|
|
84ab825b67 | ||
|
|
b7f638782c | ||
|
|
04dbb2c2bc | ||
|
|
2e1d544984 | ||
|
|
558d813ef0 | ||
|
|
5a3e24fc1e | ||
|
|
d466552e7e | ||
|
|
7e9fedce77 | ||
|
|
472bc43825 | ||
|
|
ccf4b448d7 | ||
|
|
afbb8938b9 | ||
|
|
1a271f659a | ||
|
|
14a839fc24 | ||
|
|
c72e648557 | ||
|
|
afe2062edd | ||
|
|
f2e3177b5c | ||
|
|
43a73310fd | ||
|
|
9cabdd16fe | ||
|
|
bcc1934a69 | ||
|
|
dbdb5849b6 | ||
|
|
a4baed5eb5 | ||
|
|
2e7fadb731 | ||
|
|
2dceb157c4 | ||
|
|
d9559ad781 | ||
|
|
09e829b33e | ||
|
|
e87f06ea4f | ||
|
|
4095bfa64b | ||
|
|
71728b49f5 | ||
|
|
95bbc6abd6 | ||
|
|
8a43e17be2 | ||
|
|
38122bfe30 | ||
|
|
54dc9b8900 | ||
|
|
7bc0e23c09 | ||
|
|
f5bbaa7553 | ||
|
|
ae17168585 | ||
|
|
0e62a84733 | ||
|
|
78a021cb3e | ||
|
|
d3925a5bd4 | ||
|
|
7653d36642 | ||
|
|
6e9022e947 | ||
|
|
316c0b3d32 | ||
|
|
68effeafba | ||
|
|
b5a9790ce4 | ||
|
|
e94475ef2b | ||
|
|
a752d3f32b | ||
|
|
86648d7375 | ||
|
|
f6c0b80be8 | ||
|
|
a78659a463 | ||
|
|
d074b4a348 | ||
|
|
dc2a85bc71 | ||
|
|
a92ac5c21d | ||
|
|
7b873fea90 | ||
|
|
92aeedd951 | ||
|
|
983ac6cf8a | ||
|
|
9091ad7f3f | ||
|
|
9b42ef5caa | ||
|
|
572a9546cd | ||
|
|
4379ed585f | ||
|
|
ebd69e172a | ||
|
|
b7c324b01c | ||
|
|
c75fa5925b | ||
|
|
5d52e2b5a6 | ||
|
|
08fd084d59 | ||
|
|
e79e905cdb | ||
|
|
a693896a67 | ||
|
|
4d9965a774 | ||
|
|
d93436cb6b | ||
|
|
187f17f43a | ||
|
|
8202d44a05 | ||
|
|
8fbc212895 | ||
|
|
00b31876cc | ||
|
|
36ae5000a7 | ||
|
|
067ab0d05d | ||
|
|
9dd236bffd | ||
|
|
8e9dce7bec | ||
|
|
c61f3ed629 | ||
|
|
948174dd27 | ||
|
|
21197dd8c2 | ||
|
|
150d2431fe | ||
|
|
40b8726ecd | ||
|
|
d365acbd47 | ||
|
|
1b75723b19 | ||
|
|
156412be9a | ||
|
|
2f3c6e4a2e | ||
|
|
9c3ce80fb2 | ||
|
|
07912d18d3 | ||
|
|
800be56601 | ||
|
|
f6d7db2bdb | ||
|
|
fb5eecba04 | ||
|
|
56b8473042 | ||
|
|
dc7180fb8f | ||
|
|
a4671b79b1 | ||
|
|
4e36d0ac51 | ||
|
|
f31e92bbcc | ||
|
|
64271b505a | ||
|
|
671fe64a6c | ||
|
|
1a565dad5d | ||
|
|
1fda68d3e8 | ||
|
|
bcb49cc514 | ||
|
|
1217af0c61 | ||
|
|
4a9acf244f | ||
|
|
8b96bf6029 | ||
|
|
76ea85dedd | ||
|
|
953cf6a1f4 | ||
|
|
0d3146f70f | ||
|
|
ff186b2daa | ||
|
|
52dcb766dc | ||
|
|
9f855f1fc5 | ||
|
|
7df54e099d | ||
|
|
e9258fbd87 | ||
|
|
e5f325e6cd | ||
|
|
ac4b6bf117 | ||
|
|
7e70346612 | ||
|
|
0d49fd4227 | ||
|
|
100ec25991 | ||
|
|
0f5a17403c | ||
|
|
d7c6678177 | ||
|
|
3c233a3f53 | ||
|
|
b31dc52c10 | ||
|
|
f33d54412b | ||
|
|
ca8e52fea5 | ||
|
|
c4d0c0c3c6 | ||
|
|
a1690bf1e9 | ||
|
|
e1a98f17c9 | ||
|
|
4eec355351 | ||
|
|
d2cc22092b | ||
|
|
cd8164e86e | ||
|
|
fbffc9770a | ||
|
|
fdd774693f | ||
|
|
21a9b1c1b5 | ||
|
|
b14ab1d45b | ||
|
|
1afaec236a | ||
|
|
9f25162641 | ||
|
|
e182f29619 | ||
|
|
97c649da9e | ||
|
|
74b58db6bf | ||
|
|
4116db64fd | ||
|
|
5dd2d2605b | ||
|
|
63d583638b | ||
|
|
31d237ec4c | ||
|
|
614ae56921 | ||
|
|
8d5e142580 | ||
|
|
08da350be9 | ||
|
|
77471a7573 | ||
|
|
66da5d309f | ||
|
|
c775f4cfe0 | ||
|
|
951d25e716 | ||
|
|
fbfbb5e82d | ||
|
|
7c497d0ef4 | ||
|
|
210343a7aa | ||
|
|
8a49ace78d | ||
|
|
d6c4d4a6d5 | ||
|
|
98eadc151e | ||
|
|
e4add7431d | ||
|
|
330213ca7e | ||
|
|
316b23efff | ||
|
|
346587163b | ||
|
|
d5fdfc4320 | ||
|
|
8c7759ff53 | ||
|
|
70bda146f1 | ||
|
|
dc48b7545f | ||
|
|
a38f239dd0 | ||
|
|
b2786e0606 | ||
|
|
3f17466ef1 | ||
|
|
4ce29d725f | ||
|
|
25ddfd7bad | ||
|
|
943a2dc793 | ||
|
|
b806a90bc9 | ||
|
|
a1aaae55f2 | ||
|
|
f1ded7a2ec | ||
|
|
0fa0bcd0bd | ||
|
|
568a9ee392 | ||
|
|
c0442c7307 | ||
|
|
97383e7b1d | ||
|
|
345cb8c96d | ||
|
|
76707055ff | ||
|
|
343358d3a7 | ||
|
|
57f834b07f | ||
|
|
6a12a113ff | ||
|
|
aa5a8fbcc2 | ||
|
|
c708b78cd0 | ||
|
|
27b2b08bee | ||
|
|
03bbb2c359 | ||
|
|
c832d740fb | ||
|
|
e79286b854 | ||
|
|
d30180a80d | ||
|
|
eb89b840e8 | ||
|
|
0a1fbbfb0d | ||
|
|
feeda99b17 | ||
|
|
299c3ebe69 | ||
|
|
55c6b2d5ee | ||
|
|
8b32a5de71 | ||
|
|
d32d3c6199 | ||
|
|
be42070d0f | ||
|
|
c282fc8501 | ||
|
|
400defa7c7 | ||
|
|
3cc7689d9a | ||
|
|
0ebd3ad458 | ||
|
|
cb9f636da0 | ||
|
|
b2027b7abc | ||
|
|
d3bef1e04d | ||
|
|
ac91640837 | ||
|
|
0a12e7d211 | ||
|
|
85339394aa | ||
|
|
b4d127ff47 | ||
|
|
10c259ad82 | ||
|
|
14c03d53f0 | ||
|
|
bdff3addb3 | ||
|
|
43aff0b259 | ||
|
|
51f357afb9 | ||
|
|
e230a42aa8 | ||
|
|
46080c31cd | ||
|
|
7b1bb24911 | ||
|
|
d299217a51 | ||
|
|
5bf2eb6040 | ||
|
|
89d7ba29f0 | ||
|
|
dee0d47388 | ||
|
|
6b2c225b06 | ||
|
|
d8ba8bc12e | ||
|
|
7a33d9080b | ||
|
|
6af16b8e38 | ||
|
|
d27ef4116e | ||
|
|
ca25759c74 | ||
|
|
72e6d24d06 | ||
|
|
6f42d28e7a | ||
|
|
c5b70d2e50 | ||
|
|
1d568b95e2 | ||
|
|
1c5701f214 | ||
|
|
f806b39ad4 | ||
|
|
c5b91b4dcf | ||
|
|
c961ef5836 | ||
|
|
4304a7fe5b | ||
|
|
499a4b34d6 | ||
|
|
69c8c8dc2e | ||
|
|
9d4cc0d74f | ||
|
|
0af37472ad | ||
|
|
6fcb4dfd95 | ||
|
|
b21598c031 | ||
|
|
e0654fc5fc | ||
|
|
fdd075c50f | ||
|
|
d34d02fcca | ||
|
|
8b649ecc21 | ||
|
|
9b2966ca1a | ||
|
|
561a780366 | ||
|
|
6cfe20c7dc | ||
|
|
369e387e0e | ||
|
|
9a61b82849 | ||
|
|
c6f91b51b3 | ||
|
|
432712e44f | ||
|
|
a2f49cbf98 | ||
|
|
00917d06dc | ||
|
|
e2c858b63b | ||
|
|
086aa0d03b | ||
|
|
24ae923037 | ||
|
|
2fa030438a | ||
|
|
7e90e9638c | ||
|
|
154afef12f | ||
|
|
ff5eb6dffc | ||
|
|
9e0608ba39 | ||
|
|
e74f524caf | ||
|
|
e131a49d44 | ||
|
|
dba48d554c | ||
|
|
502922be9b | ||
|
|
ebf1941182 | ||
|
|
0ac5bd7e39 | ||
|
|
12626e6e9e | ||
|
|
931d1bcce5 | ||
|
|
a9413854b5 | ||
|
|
e53a0da31e | ||
|
|
f8dfa6912f | ||
|
|
ef0f28404f | ||
|
|
b47bff8820 | ||
|
|
08ccbf93d5 | ||
|
|
fa094cdbb9 | ||
|
|
944eba8d0f | ||
|
|
10d522e388 | ||
|
|
ef816a643e | ||
|
|
d0ec418243 | ||
|
|
61825f8281 | ||
|
|
86ce362679 | ||
|
|
375b6fb802 | ||
|
|
ca8e3270fc | ||
|
|
7586aabf7d | ||
|
|
45a63c6bf1 | ||
|
|
e84d183e69 | ||
|
|
760d905c6d | ||
|
|
3aac0be31e | ||
|
|
43398647a8 | ||
|
|
9a8ed6575c | ||
|
|
aea47d7feb | ||
|
|
74e568770f | ||
|
|
ad145c4f90 | ||
|
|
0d829c8edc | ||
|
|
1e2ffde798 | ||
|
|
3897470ab5 | ||
|
|
94d38fc875 | ||
|
|
02b5135b96 | ||
|
|
de3b23ad1b | ||
|
|
6253bb71b7 | ||
|
|
873fd8d355 | ||
|
|
b37c3d8197 | ||
|
|
3a86bffb8b | ||
|
|
d510df976e | ||
|
|
efd43bc6f5 | ||
|
|
de31b2f2af | ||
|
|
a484eb4ab4 | ||
|
|
e34737ea2c | ||
|
|
20649c2cad | ||
|
|
89c83460f0 | ||
|
|
841e7857ae | ||
|
|
133c9ae5c4 | ||
|
|
2ccb9599fa | ||
|
|
98536222e3 | ||
|
|
f700e124ee | ||
|
|
e37e27af93 | ||
|
|
463a483046 | ||
|
|
996f4f2886 | ||
|
|
c98b7d5f7b | ||
|
|
5fdac299b4 | ||
|
|
9f6d79c73f | ||
|
|
858a099dce | ||
|
|
7cfd6353be | ||
|
|
acae8b1001 | ||
|
|
2c3aa80148 | ||
|
|
989a2d1911 | ||
|
|
2b50ed436e | ||
|
|
843007098b | ||
|
|
cb8686113d | ||
|
|
48fd114c67 | ||
|
|
d121031a95 | ||
|
|
03286f33c7 | ||
|
|
bc98f4489e | ||
|
|
739931ecf4 | ||
|
|
53e412a812 | ||
|
|
852df266b7 | ||
|
|
c7a7dcea44 | ||
|
|
9d3dd23cb2 | ||
|
|
730ef8236a | ||
|
|
0ffa06bf15 | ||
|
|
ee213b8c11 | ||
|
|
ddae7e19e7 | ||
|
|
0fee5d5f16 | ||
|
|
3f7dab848e | ||
|
|
12aa626302 | ||
|
|
e794b4988c | ||
|
|
cfc5459e63 | ||
|
|
2720a896d5 | ||
|
|
e3aacdf59a | ||
|
|
e0946cb41b | ||
|
|
594f367681 | ||
|
|
bf199c34b3 | ||
|
|
234a04571e | ||
|
|
157abbd42c | ||
|
|
5d0f0f380d | ||
|
|
de76248670 | ||
|
|
5305af0e74 | ||
|
|
85d025f33f | ||
|
|
75e7e7a6ff | ||
|
|
f8483c3d30 | ||
|
|
1d4e739cb8 | ||
|
|
e3806fecf3 | ||
|
|
6c6b956908 | ||
|
|
8ed51b5ba7 | ||
|
|
1f6e839d22 | ||
|
|
70b665b628 | ||
|
|
8c69e4fc51 | ||
|
|
aceac9a5ea | ||
|
|
91017ffa2e | ||
|
|
ceaf1f8063 | ||
|
|
4e7aaa3513 | ||
|
|
7e17aeedb7 | ||
|
|
a382589deb | ||
|
|
2ad8a26515 | ||
|
|
23737900c9 | ||
|
|
d2ac30cbb3 | ||
|
|
57a187b9e1 | ||
|
|
d6a2d957c8 | ||
|
|
14dcf5aab3 | ||
|
|
3fb2794967 | ||
|
|
bd45765dc7 | ||
|
|
16c7a1948c | ||
|
|
a19bb5db94 | ||
|
|
95f2281570 | ||
|
|
ac7ce6b5d2 | ||
|
|
5bfe8b93f6 | ||
|
|
4114d27f17 | ||
|
|
58235523eb | ||
|
|
3b3c87be69 | ||
|
|
aa6c164e6f | ||
|
|
ab00580d88 | ||
|
|
1b8dceae60 | ||
|
|
ba25cbb925 | ||
|
|
84a275be46 | ||
|
|
f552e84c5e | ||
|
|
ad523d5166 | ||
|
|
aa89154c82 | ||
|
|
34118c0963 | ||
|
|
c43fddac00 | ||
|
|
955ac4ee7a | ||
|
|
caa6a18b0d | ||
|
|
4c9734308f | ||
|
|
368cfb641b | ||
|
|
ae9ff3e9e1 | ||
|
|
63de785b10 | ||
|
|
a5a7c04edb | ||
|
|
081c3c2d77 | ||
|
|
e63b32a936 | ||
|
|
13a3d9cc7e | ||
|
|
ba24b6e99d | ||
|
|
4730c565f2 | ||
|
|
049029e4a7 | ||
|
|
465d82760b | ||
|
|
bc43cebf73 | ||
|
|
61acb445a0 | ||
|
|
5803294876 | ||
|
|
d4436e05cb | ||
|
|
faa687e0db | ||
|
|
98e2c2c949 | ||
|
|
50b4573823 | ||
|
|
6d7202a1c3 | ||
|
|
c348cf1dc2 | ||
|
|
667efd5fca | ||
|
|
0cf358f442 | ||
|
|
0cb59273f5 | ||
|
|
a6485970b0 | ||
|
|
3fe3f921ab | ||
|
|
726e68d1e2 | ||
|
|
76ec750a25 | ||
|
|
8627320960 | ||
|
|
bab3ef8193 | ||
|
|
d931764506 | ||
|
|
36b3d648cb | ||
|
|
572cf756da | ||
|
|
f06f365823 | ||
|
|
eaf349cd5f | ||
|
|
4f21b1f09c | ||
|
|
4efd49822e | ||
|
|
ebdf6d34f2 | ||
|
|
5f219d8b6b | ||
|
|
cef247cc17 | ||
|
|
beccba4542 | ||
|
|
2b3393be24 | ||
|
|
ebfc3662ad | ||
|
|
af23dc77f4 | ||
|
|
02db8317da | ||
|
|
7d0c65d36c | ||
|
|
8bf2b6252c | ||
|
|
85a1d3d471 | ||
|
|
1d569027a2 | ||
|
|
35ead0fc75 | ||
|
|
6c7c9426cb | ||
|
|
11caeface1 | ||
|
|
6febba372f | ||
|
|
dd4ca405dd | ||
|
|
81b14a431d | ||
|
|
9e81d0f237 | ||
|
|
99c2f4029a | ||
|
|
3e1b55a4fc | ||
|
|
84a9bf8832 | ||
|
|
27f332943d | ||
|
|
785e197f4e | ||
|
|
7170bddb69 | ||
|
|
ea5cf5d30f | ||
|
|
b4dc7b6b62 | ||
|
|
1966359e2d | ||
|
|
0db5781d9a | ||
|
|
9f2d888010 | ||
|
|
8042430f1a | ||
|
|
61785264b4 | ||
|
|
6276a51ca6 | ||
|
|
05aabd7bf7 | ||
|
|
fc7e9f4648 | ||
|
|
2ff1c053d8 | ||
|
|
a72eff4370 | ||
|
|
cc061af9a5 | ||
|
|
ee19d09134 | ||
|
|
0bd02e8771 | ||
|
|
9298968fb9 | ||
|
|
2caf1b1df1 | ||
|
|
de80670032 | ||
|
|
3002e85ba3 | ||
|
|
48b939a708 | ||
|
|
7baa9e496d | ||
|
|
5a047b837b | ||
|
|
e511419efc | ||
|
|
3c204ee395 | ||
|
|
aadfcbd0da | ||
|
|
2324e65c89 | ||
|
|
f9db8f888e | ||
|
|
116515b088 | ||
|
|
a38cf594a6 | ||
|
|
224fac0f4c | ||
|
|
a13429db0c | ||
|
|
f93981d377 | ||
|
|
651205bb9a | ||
|
|
fd82a3958d | ||
|
|
77bb261143 | ||
|
|
a7b1693fab | ||
|
|
64432046db | ||
|
|
1505e9facf | ||
|
|
24e18a0eca | ||
|
|
52d43d4889 | ||
|
|
7dcc2ae685 | ||
|
|
dcd076fd3e | ||
|
|
f0c7016249 | ||
|
|
3fda8b1d61 | ||
|
|
325fcd7a0f | ||
|
|
049765a54a | ||
|
|
1d2535dbb0 | ||
|
|
14b899ed54 | ||
|
|
129364fc53 | ||
|
|
9f1b82f337 | ||
|
|
41355b0622 | ||
|
|
ecf33acad6 | ||
|
|
c16922b859 | ||
|
|
23fd239e9e | ||
|
|
52a8de8ec0 | ||
|
|
6fb722d96b | ||
|
|
1f7094655b | ||
|
|
02960e3c4e | ||
|
|
a8b9577abc | ||
|
|
2e6f9c6707 | ||
|
|
45d0c5c27f | ||
|
|
3bf5524192 | ||
|
|
413ba9455a | ||
|
|
1d32d436a4 | ||
|
|
a447d4c685 | ||
|
|
127f43df4a | ||
|
|
5adc47ac3a | ||
|
|
d1283aed97 | ||
|
|
8be555cf80 | ||
|
|
bba4d499c2 | ||
|
|
1f8109db80 | ||
|
|
0c30f339e3 | ||
|
|
9f8fbface3 | ||
|
|
0bb550e7c2 | ||
|
|
7d12db71e3 | ||
|
|
168c9d602f | ||
|
|
9a93a52d2e | ||
|
|
66a964553f | ||
|
|
a783d1ecee | ||
|
|
e640d9f61c | ||
|
|
7463deb7a3 | ||
|
|
7d318a3a12 | ||
|
|
75699f54c4 | ||
|
|
2f3d360901 | ||
|
|
17d26f2bf7 | ||
|
|
fd6b258b63 | ||
|
|
b8bc238098 | ||
|
|
151a5b3664 | ||
|
|
adaf3abc52 | ||
|
|
fc39acfceb | ||
|
|
ae89bfcccc | ||
|
|
2d29a7c708 | ||
|
|
b880781d9e | ||
|
|
f10b216184 | ||
|
|
b6cd300d3b | ||
|
|
f9d6053313 | ||
|
|
2b231f7815 | ||
|
|
36b86a6b9a | ||
|
|
e5fd99d137 | ||
|
|
a74e933a03 | ||
|
|
a3e218efa5 | ||
|
|
4a9ff01599 | ||
|
|
6318bd3d6d | ||
|
|
b3962d125a | ||
|
|
c56782ccaf | ||
|
|
accbfab6af | ||
|
|
6024a470df | ||
|
|
b7b8c9e0ef | ||
|
|
5d15499683 | ||
|
|
5e043366c6 | ||
|
|
435219d80e | ||
|
|
8aca7d649c | ||
|
|
2861839934 | ||
|
|
40ca75e982 | ||
|
|
514d5f44a3 | ||
|
|
474c6ea913 | ||
|
|
86496c3ab9 | ||
|
|
9b77a5ed8a | ||
|
|
e2d2d8023c | ||
|
|
6999af5485 | ||
|
|
cba0e9ac0a | ||
|
|
9406886164 | ||
|
|
3d103fb1d9 | ||
|
|
165580e74f | ||
|
|
60d7398037 | ||
|
|
cd6247278a | ||
|
|
75035f2f6e | ||
|
|
40e790fd6c | ||
|
|
da2ac721b6 | ||
|
|
80f6e0ffb3 | ||
|
|
290210c560 | ||
|
|
ca166d25e9 | ||
|
|
03e1f5dc93 | ||
|
|
fd3b718980 | ||
|
|
36a82ef539 | ||
|
|
622a396916 | ||
|
|
6d04305886 | ||
|
|
de0db4e1a6 | ||
|
|
c8683d72d1 | ||
|
|
57ba8590e2 | ||
|
|
47becff4bf | ||
|
|
8e2bf62ec3 | ||
|
|
5389c00f28 | ||
|
|
337bd554a3 | ||
|
|
734e402508 | ||
|
|
7304b54af9 | ||
|
|
9564f8fd98 | ||
|
|
629d6ff548 | ||
|
|
2a76dc0fda | ||
|
|
6f41f3fcad | ||
|
|
a2af7987cc | ||
|
|
30c88a5dfd | ||
|
|
5c232baf2f | ||
|
|
88c6fe59f9 | ||
|
|
ef1532bae6 | ||
|
|
b9736aa4e9 | ||
|
|
6e1701535b | ||
|
|
2fec926bd1 | ||
|
|
332b5dc036 | ||
|
|
1c065cef73 | ||
|
|
b79fb2ec69 | ||
|
|
331f5c789d | ||
|
|
2c2f0851c0 | ||
|
|
65a473d94c | ||
|
|
9022cd4e72 | ||
|
|
088df9c6cd | ||
|
|
87cc086294 | ||
|
|
316e0c913d | ||
|
|
2b1ff161d0 | ||
|
|
5a64cf6416 | ||
|
|
cb22dd8e6a | ||
|
|
913ee40148 | ||
|
|
1c58cd26b9 | ||
|
|
e0471ecadc | ||
|
|
713f37ce72 | ||
|
|
76fddca0f5 | ||
|
|
67e38128bd | ||
|
|
948d614622 | ||
|
|
541cfcd1f1 | ||
|
|
1994d67d9e | ||
|
|
22cce0c2e1 | ||
|
|
82f6e19ade | ||
|
|
855cacfe1b | ||
|
|
8c21f3ffc1 | ||
|
|
ebed3e9baa | ||
|
|
b4c867aa43 | ||
|
|
bd3856542b | ||
|
|
232defb340 | ||
|
|
cf1b4b6bef | ||
|
|
cb4566f9ec | ||
|
|
b2b721b15a | ||
|
|
e677bca53f | ||
|
|
4cde32970d | ||
|
|
251a16aff5 | ||
|
|
ea6ca28e20 | ||
|
|
6723ee6a7d | ||
|
|
f32d75f042 | ||
|
|
162a73e1e2 | ||
|
|
154417864b | ||
|
|
05fc517390 | ||
|
|
b1482d9a9f | ||
|
|
18be7f1be6 | ||
|
|
dd899c79a1 | ||
|
|
cc6b72fbb0 | ||
|
|
7c6c675da8 | ||
|
|
119777346e | ||
|
|
2e59026f11 | ||
|
|
5888a92b2c | ||
|
|
fdb12648fc | ||
|
|
bbf3f6e1be | ||
|
|
b1e2f3352c | ||
|
|
af448a1d94 | ||
|
|
fa4a1f9f93 | ||
|
|
543801cbb6 | ||
|
|
87f19d1496 | ||
|
|
7db4a51ee1 | ||
|
|
1e1578a5c1 | ||
|
|
527a17830f | ||
|
|
3e2901088f | ||
|
|
dc1a92e365 | ||
|
|
7bfd52e5ce | ||
|
|
1cdde4aa31 | ||
|
|
35b0b97d52 | ||
|
|
44f951d4aa | ||
|
|
6d78e62f81 | ||
|
|
620eb02a04 | ||
|
|
88764ecc1a | ||
|
|
f4c6ec0624 | ||
|
|
a43db23e66 | ||
|
|
4cffa32536 | ||
|
|
237fdb87cc | ||
|
|
ae27ee29f6 | ||
|
|
5f6b023036 | ||
|
|
2b9af3a032 | ||
|
|
560fff00e3 | ||
|
|
a7385b0e3e | ||
|
|
5551a2506f | ||
|
|
8853bb7c88 | ||
|
|
fcf9708844 | ||
|
|
960c58e61b | ||
|
|
c7bbd5ad4b | ||
|
|
2dcf6a843d | ||
|
|
0cd5a18ba5 | ||
|
|
f62ac18ef5 | ||
|
|
c701a5bd1e | ||
|
|
b60f722b80 | ||
|
|
3d2fa0ca30 | ||
|
|
472d4a53f2 | ||
|
|
f6188debb6 | ||
|
|
390181f459 | ||
|
|
3a61c2e5b9 | ||
|
|
9ac44925f8 | ||
|
|
1754a3d4a4 | ||
|
|
c50b6bc766 | ||
|
|
8ef0733316 | ||
|
|
61157765c3 | ||
|
|
ccc8b43405 | ||
|
|
a6d8a961d6 | ||
|
|
2d01432f96 | ||
|
|
8b60044d67 | ||
|
|
9752ddebc1 | ||
|
|
49db7fc60d | ||
|
|
042d501cf5 | ||
|
|
14b1915b8c | ||
|
|
93466fbf69 | ||
|
|
8fa3fa95bb | ||
|
|
148a294a31 | ||
|
|
c4ff2e34e4 | ||
|
|
db8caeb5c7 | ||
|
|
71469a23d4 | ||
|
|
9f97bc2e7e | ||
|
|
8d625f656f | ||
|
|
b99ed76626 | ||
|
|
a30185cbeb | ||
|
|
a3cc42780c | ||
|
|
70e30790ea | ||
|
|
3a9956cb5d | ||
|
|
8ddea7afe0 | ||
|
|
b324cc9813 | ||
|
|
9930de7375 | ||
|
|
895679e24e | ||
|
|
6dc819dd38 | ||
|
|
57319f33a8 | ||
|
|
1082e61bd7 | ||
|
|
a9ac8e4f0a | ||
|
|
9ac801e16c | ||
|
|
32c58c64a1 | ||
|
|
82589bcfc2 | ||
|
|
5cdd696646 | ||
|
|
4f2edffe5c | ||
|
|
40940aaa98 | ||
|
|
3f73e247e6 | ||
|
|
c2e9e3bd15 | ||
|
|
498cab0c3a | ||
|
|
ab7d7a0185 | ||
|
|
d869086047 | ||
|
|
98634a5611 | ||
|
|
1ae1202d3b | ||
|
|
72d25b7df8 | ||
|
|
faa22c0da8 | ||
|
|
34a7f6a008 | ||
|
|
12b5b65f9e | ||
|
|
3083dcb0d1 | ||
|
|
fee5dad579 | ||
|
|
d1ef376d52 | ||
|
|
1e114ff79a | ||
|
|
f9b922c5e0 | ||
|
|
2ae7bdbbb6 | ||
|
|
29224bbe09 | ||
|
|
be85d7a801 | ||
|
|
e6e2e48e09 | ||
|
|
c6106687c7 | ||
|
|
c974e9176f | ||
|
|
539de05556 | ||
|
|
1d6e0cecb2 | ||
|
|
b941b23507 | ||
|
|
70f9e81393 | ||
|
|
041f7838a6 | ||
|
|
83d392eb89 | ||
|
|
d36f6f604f | ||
|
|
dae72454e4 | ||
|
|
69643d437b | ||
|
|
38799633a3 | ||
|
|
12e3ceba61 | ||
|
|
a7061c3551 | ||
|
|
5773db5e96 | ||
|
|
b2a4e589a0 | ||
|
|
6f52de4ac0 | ||
|
|
7b882ce065 | ||
|
|
ad5c37ef7a | ||
|
|
cc43fdef97 | ||
|
|
7033cf2586 | ||
|
|
8dcd376cc0 | ||
|
|
92b12c0455 | ||
|
|
884c98d241 | ||
|
|
a8ae06a94d | ||
|
|
f571ee5f0e | ||
|
|
539a215863 | ||
|
|
04b0d45c13 | ||
|
|
e0a1824870 | ||
|
|
b1748d4cff | ||
|
|
2ca5b0f469 | ||
|
|
9e2830bf52 | ||
|
|
2528d0646c | ||
|
|
ac2fd78191 | ||
|
|
8feda2f95c | ||
|
|
ab5d79a8ce | ||
|
|
7c64a2f075 | ||
|
|
87126d5651 | ||
|
|
7359fe84a0 | ||
|
|
636f6e5c0b | ||
|
|
bd5ed16009 | ||
|
|
937f4e48fe | ||
|
|
5a28a174e4 | ||
|
|
7139d3ae5e | ||
|
|
6ebdb2a63c | ||
|
|
13f95a76d1 | ||
|
|
0def7db2ea | ||
|
|
4b892ab691 | ||
|
|
6a18367f41 | ||
|
|
9ef8e41d1e | ||
|
|
f2c28f0f96 | ||
|
|
7d8efdeda0 | ||
|
|
8f81d9d757 | ||
|
|
2e8c8ec706 | ||
|
|
5d5c36b37a | ||
|
|
fe65dfcc3a | ||
|
|
42288e4842 | ||
|
|
ad48701d87 | ||
|
|
2571458361 | ||
|
|
92ffe487b3 | ||
|
|
3c8a306ed0 | ||
|
|
97441a2446 | ||
|
|
b5a0bf7fe3 | ||
|
|
2d76756908 | ||
|
|
12369484b2 | ||
|
|
c6e608ab38 | ||
|
|
4bbd4c1bc1 | ||
|
|
5219c0f7a6 | ||
|
|
bbcca8587c | ||
|
|
2fd4ee7a48 | ||
|
|
8be09b6814 | ||
|
|
1f2fa05492 | ||
|
|
af1a5bbdcf | ||
|
|
8cf013b9ab | ||
|
|
dfd554f271 | ||
|
|
a1cb8c1cdb | ||
|
|
69516b8fd2 | ||
|
|
824ce77efa | ||
|
|
af2f5dff29 | ||
|
|
e70ef8e192 | ||
|
|
f8e81baabd | ||
|
|
3e185f7404 | ||
|
|
ef63d3a6b0 | ||
|
|
b5baf3fccb | ||
|
|
6217d3f6e7 | ||
|
|
56b0cb2438 | ||
|
|
70fa8cdef7 | ||
|
|
f5501fd149 | ||
|
|
68b0b59cc0 | ||
|
|
2c422b0146 | ||
|
|
1694d87acd | ||
|
|
824abdcc9b | ||
|
|
d341457ccb | ||
|
|
46e73612ba | ||
|
|
555e7be7db | ||
|
|
371edcd97e | ||
|
|
b4db4084c8 | ||
|
|
c82ba656fb | ||
|
|
d027b768d1 | ||
|
|
f54333676b | ||
|
|
8f9f580ca4 | ||
|
|
6dd9a28428 | ||
|
|
c103a0a3aa | ||
|
|
32ff92edc5 | ||
|
|
a9c913d6fd | ||
|
|
073ed31cbe | ||
|
|
77405d7520 | ||
|
|
22e4b3d98d | ||
|
|
0e022b2440 | ||
|
|
0dd8bc3e95 | ||
|
|
f2ff9f7f33 | ||
|
|
1971f871ec | ||
|
|
e25daddac3 | ||
|
|
9780bab889 | ||
|
|
dd6fbf77a7 | ||
|
|
58d238c41c | ||
|
|
befd9fcb1c | ||
|
|
358391dd8e | ||
|
|
25d041e298 | ||
|
|
f7b655eaf7 | ||
|
|
4c6a363485 | ||
|
|
3985d8ddba | ||
|
|
efe319da10 | ||
|
|
400d87eba2 | ||
|
|
c77dc48cdc | ||
|
|
8024d620cc | ||
|
|
ae4f6afd07 | ||
|
|
46b7904bd9 | ||
|
|
dac756aa08 | ||
|
|
bc6644fc8b | ||
|
|
cd8d48a0e9 | ||
|
|
f5f47f26fc | ||
|
|
7eed6823a1 | ||
|
|
e945da32e5 | ||
|
|
444a8701d6 | ||
|
|
6fead7b970 | ||
|
|
17514ea0ec | ||
|
|
1130634688 | ||
|
|
f9545ae1b6 | ||
|
|
ead1e453d0 | ||
|
|
c158bf75de | ||
|
|
5e715448e3 | ||
|
|
925765c6fe | ||
|
|
5d675b2543 | ||
|
|
0deacd4922 | ||
|
|
a0da2d3239 | ||
|
|
1ae90ef670 | ||
|
|
860146a0e6 | ||
|
|
e455d2f82d | ||
|
|
9331f4d366 | ||
|
|
c95e430435 | ||
|
|
227e8dfd75 | ||
|
|
dfa4f3f011 | ||
|
|
5f0fc58f5d | ||
|
|
e309aa232a | ||
|
|
5daa08c66b | ||
|
|
9622765d8d | ||
|
|
099a23c908 | ||
|
|
a03073fc67 | ||
|
|
026a3b5011 | ||
|
|
d57b630002 | ||
|
|
25c92ead63 | ||
|
|
77a379be4a | ||
|
|
8d2c1b95a6 | ||
|
|
63a5128ddd | ||
|
|
5fabb97724 | ||
|
|
148a343b59 | ||
|
|
50c5ec9124 | ||
|
|
b161be69ed | ||
|
|
af77fd5d91 | ||
|
|
938bf33dde | ||
|
|
882d285f35 | ||
|
|
7a74547ec0 | ||
|
|
f7b4b2ec6e | ||
|
|
8aae5c7bdf | ||
|
|
7553f860b1 | ||
|
|
d8a844f0da | ||
|
|
f63c19df79 | ||
|
|
db66b7720a | ||
|
|
1148da3047 | ||
|
|
68265148d7 | ||
|
|
c3dc721ba5 | ||
|
|
223d7cff11 | ||
|
|
785108f332 | ||
|
|
7a24d9b88e | ||
|
|
3d439ded6d | ||
|
|
b76ce64cc5 | ||
|
|
d2bb354d98 | ||
|
|
0def262fd0 | ||
|
|
be2223b690 | ||
|
|
483fcab70f | ||
|
|
a730a046da | ||
|
|
a717df13b2 | ||
|
|
a67b08205d | ||
|
|
058ba5041b | ||
|
|
403623a693 | ||
|
|
0612ff45fa | ||
|
|
4fbb89341f | ||
|
|
a633da255c | ||
|
|
23644222aa | ||
|
|
c0091d8046 | ||
|
|
f850de5405 | ||
|
|
0c4826d286 | ||
|
|
2632711272 | ||
|
|
537e64cf31 | ||
|
|
72eebcef0c | ||
|
|
bbd6ccd8cb | ||
|
|
0fb50b4aa7 | ||
|
|
c36a54c76b | ||
|
|
18adef4857 | ||
|
|
afffb11b6a | ||
|
|
7bd3d8bc7c | ||
|
|
2f786d97d5 | ||
|
|
bc54efada7 | ||
|
|
76eb2e4476 | ||
|
|
0d185828b6 | ||
|
|
06911f8c65 | ||
|
|
5d9e3d466e | ||
|
|
ece9b256f3 | ||
|
|
49ffe54807 | ||
|
|
c4e4caba0e | ||
|
|
3dc75ca750 | ||
|
|
e9bcf6b977 | ||
|
|
344901d3a6 | ||
|
|
a56416f9c8 | ||
|
|
0dd451935e | ||
|
|
5cdc2f00ab | ||
|
|
e67875114f | ||
|
|
17a3ce53b4 | ||
|
|
2c8bc35597 | ||
|
|
79d0464bdc | ||
|
|
95fcc2093b | ||
|
|
be93a9eadf | ||
|
|
8cbaa89f4a | ||
|
|
bbcc8dec0d | ||
|
|
3b88bbb499 | ||
|
|
b588262a85 | ||
|
|
08216f3d5d | ||
|
|
ab2cea7a0f | ||
|
|
5badb261c6 | ||
|
|
7932348852 | ||
|
|
b95ff7a37b | ||
|
|
ea811cdb79 | ||
|
|
0de7f94893 | ||
|
|
df91b447c3 | ||
|
|
0dbbed1ff7 | ||
|
|
3e9da65867 | ||
|
|
ca742a5d0c | ||
|
|
9046645590 | ||
|
|
c79e062121 | ||
|
|
112ec23e08 | ||
|
|
2c84d1bc14 | ||
|
|
4ea59adb33 | ||
|
|
625fae7d5b | ||
|
|
d2d4f2d604 | ||
|
|
bbd4e57723 | ||
|
|
beb78f38ed | ||
|
|
dcf7bd7820 | ||
|
|
3e189780d4 | ||
|
|
96eb0e6b49 | ||
|
|
2ec9078e65 | ||
|
|
5ce85dc349 | ||
|
|
bdd70c0563 | ||
|
|
8de8d53dd1 | ||
|
|
593c62a5a1 | ||
|
|
f1988c94cd | ||
|
|
0883e7ac0e | ||
|
|
ae1840341f | ||
|
|
a7e89e119c | ||
|
|
208864add2 | ||
|
|
e85d299448 | ||
|
|
46d881a57a | ||
|
|
a95153f6d9 | ||
|
|
3eb96ecae8 | ||
|
|
650feba0e8 | ||
|
|
1903308851 | ||
|
|
b2e16cc28e | ||
|
|
79b7a598aa | ||
|
|
cf4dd08253 | ||
|
|
976f101776 | ||
|
|
b967391120 | ||
|
|
f17f36e9a0 | ||
|
|
cedc3eb98e | ||
|
|
1fdd8b9c37 | ||
|
|
db44f48cf6 | ||
|
|
cda0ec1e77 | ||
|
|
490ceb7def | ||
|
|
cfbdeac226 | ||
|
|
c20d1fa779 | ||
|
|
2a5246ae62 | ||
|
|
5bdd7244d3 | ||
|
|
0878200e01 | ||
|
|
f673fb2660 | ||
|
|
f8e96a3d8c | ||
|
|
961c5d58b4 | ||
|
|
b0b95af274 | ||
|
|
537a65a978 | ||
|
|
5351b53277 | ||
|
|
63aa473f66 | ||
|
|
956d937a89 | ||
|
|
11754b7cfb | ||
|
|
69114a859b | ||
|
|
440019dc59 | ||
|
|
b91fe8a625 | ||
|
|
b610ced88b | ||
|
|
9405b118eb | ||
|
|
478ac21c7d | ||
|
|
92c5704820 | ||
|
|
aaea94c9ed | ||
|
|
96f26fa323 | ||
|
|
bc31ff7ea2 | ||
|
|
dca4922141 | ||
|
|
e428eb1364 | ||
|
|
ae99e55eb1 | ||
|
|
6000cff48e | ||
|
|
4c0833bf68 | ||
|
|
00096aeca2 | ||
|
|
8b1b45b1b6 | ||
|
|
02c82b2765 | ||
|
|
f737b21e40 | ||
|
|
fdb10f6623 | ||
|
|
2908b62b26 | ||
|
|
238180edf5 | ||
|
|
5aa1296ffa | ||
|
|
5f55d6b5f9 | ||
|
|
6bcf1d5666 | ||
|
|
fc5ed95195 | ||
|
|
9f5ce8cb2f | ||
|
|
ec82d26168 | ||
|
|
124c47369f | ||
|
|
b0f688ede7 | ||
|
|
c5e8281e6a | ||
|
|
64d9692437 | ||
|
|
0fe3fbd296 | ||
|
|
b767dd20a3 | ||
|
|
2fcf3facf0 | ||
|
|
e9b8bfeddf | ||
|
|
4a018be8bf | ||
|
|
1e9b520e26 | ||
|
|
3ce3a4e5b1 | ||
|
|
3b59911b9e | ||
|
|
67997337b2 | ||
|
|
9b723f428e | ||
|
|
46100e2a95 | ||
|
|
351283c0c8 | ||
|
|
eb7d477357 | ||
|
|
471830d59d | ||
|
|
d963e2a54e | ||
|
|
1613b9d9f7 | ||
|
|
70834c1294 | ||
|
|
64606dcc5c | ||
|
|
5ba897a2bc | ||
|
|
ec9929d939 | ||
|
|
22b9df302f | ||
|
|
d931863c8a | ||
|
|
9710026def | ||
|
|
f2b4c88b0e | ||
|
|
d8345f808d | ||
|
|
51f4df4c59 | ||
|
|
9fe57a8360 | ||
|
|
55bf3bf35c | ||
|
|
5ab6963e3d | ||
|
|
553ed226de | ||
|
|
c2cec7473f | ||
|
|
9a77142dda | ||
|
|
84548ea2ec | ||
|
|
7d8e0a9300 | ||
|
|
f97518b49a | ||
|
|
29e259af54 | ||
|
|
9ede227593 | ||
|
|
0ed8b45e70 | ||
|
|
463791c7f5 | ||
|
|
d437414110 | ||
|
|
657e078607 | ||
|
|
a2b6851154 | ||
|
|
f7c44ca8d7 | ||
|
|
e7e90e6afe | ||
|
|
78f595ce51 | ||
|
|
cc3413a7b9 | ||
|
|
5d6b4ebb1c | ||
|
|
5ea5c50340 | ||
|
|
80b4d7b3e8 | ||
|
|
23de468e43 | ||
|
|
b0df114710 | ||
|
|
a0be5a118b | ||
|
|
edfb785958 | ||
|
|
7c9fcc9e17 | ||
|
|
ab62335860 | ||
|
|
3f21d93bc9 | ||
|
|
587d8791ff | ||
|
|
40ba3857ef | ||
|
|
d44810d686 | ||
|
|
1f3727b5a7 | ||
|
|
336d2fa9d8 | ||
|
|
62aaf43375 | ||
|
|
975f539560 | ||
|
|
cefda66c70 | ||
|
|
fd0a1da0a7 | ||
|
|
f6f3a93bc4 | ||
|
|
f9b9b21f46 | ||
|
|
a8aa714370 | ||
|
|
3ec89028a1 | ||
|
|
21fd5d26c2 | ||
|
|
110d275401 | ||
|
|
b66453d5f8 | ||
|
|
aef050fa9e | ||
|
|
d08f533252 | ||
|
|
a75be26c1f | ||
|
|
9c090b468d | ||
|
|
4f0e2ffced | ||
|
|
6a04003330 | ||
|
|
d062747473 | ||
|
|
828141d1f9 | ||
|
|
feef2696b6 | ||
|
|
c3870d72a7 | ||
|
|
91211deb01 | ||
|
|
b2ebd79911 | ||
|
|
86788787ab | ||
|
|
c216fc22e6 | ||
|
|
377045775f | ||
|
|
9b1d70130b | ||
|
|
6ce3a3b327 | ||
|
|
39dd0f0be3 | ||
|
|
2de30a84a8 | ||
|
|
7e2b87c39b | ||
|
|
419c45593b | ||
|
|
06e5ebbbfc | ||
|
|
06926ae97c | ||
|
|
e5a3e6a374 | ||
|
|
3fcfdbcdaa | ||
|
|
1bf61dbffd | ||
|
|
885eeb63b2 | ||
|
|
e03211351a | ||
|
|
f0cfb9b7df | ||
|
|
07eefb39aa | ||
|
|
5e7866f33d | ||
|
|
4f16130684 | ||
|
|
90c3d3eb5d | ||
|
|
23b11bb0ba | ||
|
|
43ea927e3f | ||
|
|
2a5ca6ac71 | ||
|
|
3b8fab2c0d | ||
|
|
9f84c51255 | ||
|
|
3cb1774f76 | ||
|
|
7b9da32063 | ||
|
|
d32a4183aa | ||
|
|
8d52416b12 | ||
|
|
4117fa4362 | ||
|
|
9b6a511a1d | ||
|
|
be0f63cd53 | ||
|
|
8a7c77ff8c | ||
|
|
2a62baeaa6 | ||
|
|
adba3d4ddf | ||
|
|
4d2929d43b | ||
|
|
cb48e1f63a | ||
|
|
556d5d2ce2 | ||
|
|
997045aa40 | ||
|
|
a1feac2080 | ||
|
|
49aa84b2b2 | ||
|
|
663530f4ec | ||
|
|
02e780346b | ||
|
|
d7ab94fddf | ||
|
|
4d19217ab1 | ||
|
|
3c35d73e91 | ||
|
|
55c95aba72 | ||
|
|
c594ca7b92 | ||
|
|
164e90a3ff | ||
|
|
c9cdab48a2 | ||
|
|
a8a2c9dccc | ||
|
|
a296eda4b0 | ||
|
|
ad27b42385 | ||
|
|
ade1b17ac8 | ||
|
|
3f9fb254af | ||
|
|
35401d6ca3 | ||
|
|
e09c02d73b | ||
|
|
aa6c2efac3 | ||
|
|
06e22e2f13 | ||
|
|
dd5ca571c5 | ||
|
|
e27feaa680 | ||
|
|
a380295f68 | ||
|
|
07dcdf7377 | ||
|
|
993621fed8 | ||
|
|
b5222a5f50 | ||
|
|
6096f2556c | ||
|
|
d43ddf6abc | ||
|
|
2d2b7cca7f | ||
|
|
d0757d3380 | ||
|
|
92c5f4bf7b | ||
|
|
806526bfbe | ||
|
|
c5c5b0448f | ||
|
|
8b51c282b2 | ||
|
|
0dad09a9ff | ||
|
|
d34c8fed00 | ||
|
|
de24bc7432 | ||
|
|
4f50605350 | ||
|
|
3e3246b623 | ||
|
|
d55615ab1f | ||
|
|
f27126bc07 | ||
|
|
e38304b74f | ||
|
|
1761fe1524 | ||
|
|
2078b95d5f | ||
|
|
8baf357d6e | ||
|
|
089fee7ccd | ||
|
|
7dfa108a92 | ||
|
|
14b56d7c55 | ||
|
|
bda499b26a | ||
|
|
39e11a33bc | ||
|
|
83a1b0ea14 | ||
|
|
48fa075994 | ||
|
|
7959e0ebd6 | ||
|
|
e6aae3dc73 | ||
|
|
21e14a6f0a | ||
|
|
45fc1e006f | ||
|
|
147376b844 | ||
|
|
a7d0d14405 | ||
|
|
fe41065839 | ||
|
|
196c3914ed | ||
|
|
026633767c | ||
|
|
c31c23a3ec | ||
|
|
ebcc44df6e | ||
|
|
be12d50198 | ||
|
|
bc72d04651 | ||
|
|
ed17251dec | ||
|
|
557ffd0b8b | ||
|
|
8c6b9bed00 | ||
|
|
0b5e69d2bc | ||
|
|
ab1b9d8b40 | ||
|
|
042ca4bd39 | ||
|
|
44db53caaf | ||
|
|
a931aafb97 | ||
|
|
75979255d1 | ||
|
|
beb675c4db | ||
|
|
37a1eaaa29 | ||
|
|
a99e1c222a | ||
|
|
3b2ddf7273 | ||
|
|
1fc0704187 | ||
|
|
8cc7a286e5 | ||
|
|
52a77adfe6 | ||
|
|
48893c1007 | ||
|
|
890b988890 | ||
|
|
45fcc6ffce | ||
|
|
f9dee772d0 | ||
|
|
3e84b09b85 | ||
|
|
9c064e3384 | ||
|
|
45f4867a00 | ||
|
|
98d7ba5cd0 | ||
|
|
ea5ccf9783 | ||
|
|
192b07042d | ||
|
|
9bd6dc0bff | ||
|
|
387894c935 | ||
|
|
927be24632 | ||
|
|
c0d7abbacd | ||
|
|
bee050d0ad | ||
|
|
3eb840db66 | ||
|
|
5e3b9d40d6 | ||
|
|
27052f6309 | ||
|
|
10fb525cb7 | ||
|
|
73e6adcbbd | ||
|
|
d3401a6a41 | ||
|
|
5f28020c9e | ||
|
|
290fc621ae | ||
|
|
b53e2e77eb | ||
|
|
ce7b1f4366 | ||
|
|
b7c152fb65 | ||
|
|
03b1b5e683 | ||
|
|
a885b5e2b5 | ||
|
|
783c89a9d0 | ||
|
|
89c9e11056 | ||
|
|
2a01958d1d | ||
|
|
aa68bf096b | ||
|
|
625d0fd4ff | ||
|
|
e75eae4bfc | ||
|
|
75f2e6638d | ||
|
|
c29ad9ed00 | ||
|
|
7ddf70e06d | ||
|
|
926c5b0db0 | ||
|
|
a1d400a3b5 | ||
|
|
3886826ca7 | ||
|
|
5753239a83 | ||
|
|
1c075acf23 | ||
|
|
844b170d0e | ||
|
|
a03714dc32 | ||
|
|
9bc05225dd | ||
|
|
2809c6dcaf | ||
|
|
bc924954c8 | ||
|
|
1e16f99e1f | ||
|
|
ddfcf12610 | ||
|
|
0faefc0327 | ||
|
|
2f786587b8 | ||
|
|
a2f3c90b17 | ||
|
|
39a866e8e1 | ||
|
|
6d0ea0d66b | ||
|
|
e2eb1651ce | ||
|
|
d8e128d4a1 | ||
|
|
9d6ade6768 | ||
|
|
a584362257 | ||
|
|
ccb6e5bda0 | ||
|
|
6a6c711eb7 | ||
|
|
3de6b34150 | ||
|
|
3000ab1a91 | ||
|
|
f8a5ed7807 | ||
|
|
d628f00e30 | ||
|
|
1d75571f8a | ||
|
|
54efed6e94 | ||
|
|
2650ee7ada | ||
|
|
4d8385b761 | ||
|
|
a5384d29cd | ||
|
|
7e1397e0c2 | ||
|
|
2cf000fbf9 | ||
|
|
81b1a38efc | ||
|
|
bc616e7e03 | ||
|
|
d7b0bf7e99 | ||
|
|
988f6e496b | ||
|
|
cad95767e5 | ||
|
|
e87c2aa797 | ||
|
|
abcd6a748e | ||
|
|
8f2400b4cc | ||
|
|
0cf70c39fb | ||
|
|
8593e1b316 | ||
|
|
9ce3876cfc | ||
|
|
21b3b8a96c | ||
|
|
efbd8c34f1 | ||
|
|
fd1484aa2e | ||
|
|
03b6a06dbb | ||
|
|
2f920d4a99 | ||
|
|
05604dd935 | ||
|
|
bb300000f2 | ||
|
|
c767f25441 | ||
|
|
5f08cc8b3b | ||
|
|
7d53a88705 | ||
|
|
6f7a979cf3 | ||
|
|
7773b64390 | ||
|
|
7e9733350e | ||
|
|
ba5c406d27 | ||
|
|
32301e016b | ||
|
|
ee48de6bae | ||
|
|
555153ed3e | ||
|
|
87e960ae4b | ||
|
|
c94208ed50 | ||
|
|
14bc9ab8b0 | ||
|
|
8d02342d5d | ||
|
|
cf9a15e9d6 | ||
|
|
e2b9102e16 | ||
|
|
f5371e1096 | ||
|
|
ea712c813a | ||
|
|
0d68b63e5b | ||
|
|
20ecbf8216 | ||
|
|
6bcf7708b2 | ||
|
|
ea8e8f95b4 | ||
|
|
6e9cf566c6 | ||
|
|
dd4f998b14 | ||
|
|
15cf9ffd37 | ||
|
|
6abd7f6495 | ||
|
|
a6580594ec | ||
|
|
d06c286fe0 | ||
|
|
357ab5d1fd | ||
|
|
475b1407c6 | ||
|
|
4947a76711 | ||
|
|
af508b28ba | ||
|
|
c59e6903de | ||
|
|
3d4e626b29 | ||
|
|
0d4295ad72 | ||
|
|
4e4e9935b7 | ||
|
|
669458b997 | ||
|
|
498f1d30f0 | ||
|
|
1967215f54 | ||
|
|
e219a1bccf | ||
|
|
4f43dad1ab | ||
|
|
f0e7cdcca0 | ||
|
|
a1f59e4678 | ||
|
|
75f7d73acd | ||
|
|
e83ce75a14 | ||
|
|
86ffc4bc1d | ||
|
|
14e7f2f34e | ||
|
|
725ffafdcc | ||
|
|
7216addaa8 | ||
|
|
3490fe6601 | ||
|
|
568f38b7e9 | ||
|
|
c4d0c46358 | ||
|
|
87156a3bc4 | ||
|
|
93a785cfaa | ||
|
|
574c6cc3be | ||
|
|
6b31af1707 | ||
|
|
4f246d0f8f | ||
|
|
de43ad2798 | ||
|
|
5fae0734e1 | ||
|
|
4b12f13594 | ||
|
|
bd659a8a65 | ||
|
|
f29f7d7d08 | ||
|
|
6f7e5134ba | ||
|
|
e1ecc686f8 | ||
|
|
ef3d710ebd | ||
|
|
15ea415ecd | ||
|
|
e6d9a37f57 | ||
|
|
0e24c7c6db | ||
|
|
58a41cb1de | ||
|
|
3f10da5472 | ||
|
|
5a4ce3a795 | ||
|
|
00ffccce9e | ||
|
|
4737231ff0 | ||
|
|
fa6f9810e8 | ||
|
|
9ea069fca3 | ||
|
|
1c5405b71c | ||
|
|
2b5f22efe7 | ||
|
|
93684206c2 | ||
|
|
4a8a8e67ed | ||
|
|
f195cb9aa6 | ||
|
|
78d952f596 | ||
|
|
f15c7bbd1d | ||
|
|
ab9d9ae079 | ||
|
|
ac7c4dd196 | ||
|
|
37b43de920 | ||
|
|
71dd1f9d97 | ||
|
|
3f0f2b961f | ||
|
|
306a4bae31 | ||
|
|
37226e531d | ||
|
|
e153caeaf0 | ||
|
|
63a9b33472 | ||
|
|
db0f5184f8 | ||
|
|
9c30901811 | ||
|
|
4e1a66fe85 | ||
|
|
af2539cc63 | ||
|
|
8036b4feed | ||
|
|
c30bc5b60a | ||
|
|
bd3cbb21f9 | ||
|
|
52425788e1 | ||
|
|
f7ce7e824b | ||
|
|
034b302b49 | ||
|
|
d5cdd4bacc | ||
|
|
0074e9995f | ||
|
|
c42d52b38d | ||
|
|
2eb21881a8 | ||
|
|
2c886d02a7 | ||
|
|
5dedf78e24 | ||
|
|
b6ff9d49c1 | ||
|
|
7499f73c64 | ||
|
|
f49fdbb02b | ||
|
|
b194c827b9 | ||
|
|
265ff45db1 | ||
|
|
f885e92571 | ||
|
|
51d8606474 | ||
|
|
807d107db8 | ||
|
|
a4548bfd03 | ||
|
|
6e673422ad | ||
|
|
07327bded2 | ||
|
|
b9e30db11c | ||
|
|
5d4b55cc5e | ||
|
|
0c20598f57 | ||
|
|
5a4b41d075 | ||
|
|
1a12486d0b | ||
|
|
574a98259b | ||
|
|
78be476aec | ||
|
|
cae4064fdf | ||
|
|
8d19d7631f | ||
|
|
1f1b7d8ab8 | ||
|
|
481d363055 | ||
|
|
a1b33eed84 | ||
|
|
2eb61bf49f | ||
|
|
f5e18d731a | ||
|
|
7ae5f0b764 | ||
|
|
9e8f561044 | ||
|
|
1415aebba4 | ||
|
|
489f75a104 | ||
|
|
660f68aa1e | ||
|
|
91ccde7291 | ||
|
|
739e8b3ec9 | ||
|
|
9e73976081 | ||
|
|
b3e7c737bb | ||
|
|
838085ac2b | ||
|
|
87c7762c62 | ||
|
|
da0d5fda24 | ||
|
|
75a0c4d5f2 | ||
|
|
f60da36c5b | ||
|
|
fec9150769 | ||
|
|
4aa4410a08 | ||
|
|
022c39ec18 | ||
|
|
ddbeb5aba5 | ||
|
|
472d7ea2d5 | ||
|
|
a11db5e8cd | ||
|
|
04dbef011a | ||
|
|
ce60eeea91 | ||
|
|
01708de3fe | ||
|
|
a58e69e038 | ||
|
|
aef7233339 | ||
|
|
406137be12 | ||
|
|
b300e35b4c | ||
|
|
a0f21c5acd | ||
|
|
879f8666e4 | ||
|
|
4c068c7d5f | ||
|
|
8007fc350d | ||
|
|
c93b184562 | ||
|
|
ad48036f17 | ||
|
|
c6a689bcbd | ||
|
|
a67f2c7dc4 | ||
|
|
388162ef56 | ||
|
|
501293d458 | ||
|
|
8ec6a1de4b | ||
|
|
72f780676b | ||
|
|
9d3d4fa61a | ||
|
|
306c0a82cd | ||
|
|
e57daaabcb | ||
|
|
2ad56b351c | ||
|
|
77348673ef | ||
|
|
7c72adf5ec | ||
|
|
a431218b40 | ||
|
|
8490d753d8 | ||
|
|
41c6ffff75 | ||
|
|
9b44d7d828 | ||
|
|
8dcf088bf3 | ||
|
|
cb8731da19 | ||
|
|
91433ce436 | ||
|
|
45a81b468a | ||
|
|
60b338229d | ||
|
|
7abb75aa7e | ||
|
|
cbd521f14f | ||
|
|
68495f54bc | ||
|
|
9e3161b2d8 | ||
|
|
57e07411f0 | ||
|
|
ffa788536f | ||
|
|
6445b23318 | ||
|
|
a72685c2b5 | ||
|
|
e7761cca10 | ||
|
|
4c84af0a68 | ||
|
|
19edf7ae06 | ||
|
|
7eb42b32b5 | ||
|
|
3fd2cf0a01 | ||
|
|
4e47313118 | ||
|
|
9a664abf31 | ||
|
|
7471081794 | ||
|
|
435edfa24e | ||
|
|
af4bc8a874 | ||
|
|
cbcea69fad | ||
|
|
7c4a3f48a0 | ||
|
|
b7e8220b5e | ||
|
|
957013759a | ||
|
|
88da4849b4 | ||
|
|
506d59a939 | ||
|
|
5477964f63 | ||
|
|
1a88c7d883 | ||
|
|
7d6342021f | ||
|
|
cde7698e9b | ||
|
|
593efda046 | ||
|
|
accba721dc | ||
|
|
e07cdb34e9 | ||
|
|
8fb5570127 | ||
|
|
e3edfec6e9 | ||
|
|
4bb65ddbf3 | ||
|
|
d64215e42e | ||
|
|
a32f5d2a29 | ||
|
|
e40457dada | ||
|
|
6b92209e51 | ||
|
|
dea3101fba | ||
|
|
058899081d | ||
|
|
5bf0a04c21 | ||
|
|
3ef739b3e6 | ||
|
|
711710211c | ||
|
|
800cfe496e | ||
|
|
eba2613668 | ||
|
|
93ebbf2e71 | ||
|
|
3a69039b73 | ||
|
|
13ab16643c | ||
|
|
0065209b5a | ||
|
|
04b514bdef | ||
|
|
20d5f79967 | ||
|
|
3e36418ced | ||
|
|
9d48a6cff8 | ||
|
|
9b899c2889 | ||
|
|
f7690cec10 | ||
|
|
01fa23d1da | ||
|
|
ebbc75d772 | ||
|
|
4b6cb7d86c | ||
|
|
d611ec64ed | ||
|
|
3aefa51e63 | ||
|
|
e4cdbe9387 | ||
|
|
e8c7db81ad | ||
|
|
571a8d051c | ||
|
|
ebb69da279 | ||
|
|
f256688bac | ||
|
|
3a83eeb52d | ||
|
|
425570290b | ||
|
|
2051a4ff62 | ||
|
|
1a2c8dd860 | ||
|
|
6822088413 | ||
|
|
56e99309d7 | ||
|
|
9ff348b675 | ||
|
|
8950c32d5e | ||
|
|
e2136f386c | ||
|
|
398a70cf77 | ||
|
|
520644440a | ||
|
|
0621a865c9 | ||
|
|
5e4afca163 | ||
|
|
6896b5cb7e | ||
|
|
b5dc37b50a | ||
|
|
921b3ed5f1 | ||
|
|
16c989588c | ||
|
|
ca3b97ff34 | ||
|
|
b4217fcc84 | ||
|
|
18649b3ef5 | ||
|
|
c22605844a | ||
|
|
f9a9655012 | ||
|
|
180407bce1 | ||
|
|
53aa98ed09 | ||
|
|
abb48b7aa8 | ||
|
|
7135529c97 | ||
|
|
737d65cfe0 | ||
|
|
6c606a1b23 | ||
|
|
b248ec9c8f | ||
|
|
2e571491b9 | ||
|
|
48f0eb8a06 | ||
|
|
3c05aa66c1 | ||
|
|
6bcbcc62c2 | ||
|
|
ed80d2dea9 | ||
|
|
70a44a040d | ||
|
|
ce3981e051 | ||
|
|
273eb0e2d1 | ||
|
|
566ff7b6cf | ||
|
|
1f26e86834 | ||
|
|
64506faad2 | ||
|
|
4616cd6ef0 | ||
|
|
1c5bb57ecf | ||
|
|
f52816824c | ||
|
|
3df309f110 | ||
|
|
cd44ff2074 | ||
|
|
b0bf0e7e35 | ||
|
|
d71e9a7356 | ||
|
|
ca98335025 | ||
|
|
d652231c6b | ||
|
|
aef695245f | ||
|
|
d859083131 | ||
|
|
663e5e493b | ||
|
|
edc821065d | ||
|
|
199c6a9041 | ||
|
|
c925f19739 | ||
|
|
ae00be7592 | ||
|
|
89b5f5c8c4 | ||
|
|
0985c42fdd | ||
|
|
f79c3a0067 | ||
|
|
5c0d0f6cc2 | ||
|
|
2d964549c9 | ||
|
|
5de07ddceb | ||
|
|
bdd4403868 | ||
|
|
33bd214f17 | ||
|
|
bcb8e8b19f | ||
|
|
6cf214a0f4 | ||
|
|
6532d40ba0 | ||
|
|
fe66ff871a | ||
|
|
345fa61777 | ||
|
|
c43aa963d8 | ||
|
|
b2a28142bd | ||
|
|
c81beeed68 | ||
|
|
f231711f77 | ||
|
|
f76c69335c | ||
|
|
ecaf4711a6 | ||
|
|
38746e18a4 | ||
|
|
f335d09875 | ||
|
|
dbbcc69edb | ||
|
|
6c483b837b | ||
|
|
348e831816 | ||
|
|
703b6cf608 | ||
|
|
d6cb339c6c | ||
|
|
5655616903 | ||
|
|
549ecc492b | ||
|
|
9a2534840b | ||
|
|
5281bed8e4 | ||
|
|
032200ac65 | ||
|
|
7877b641fa | ||
|
|
8932b2b60e | ||
|
|
596c36ac43 | ||
|
|
b65f42aa7a | ||
|
|
076d1f315e | ||
|
|
e3f9f5c9a6 | ||
|
|
33c8c84b35 | ||
|
|
ecb94a711e | ||
|
|
f487367875 | ||
|
|
3b818e9dec | ||
|
|
9ff6538f47 | ||
|
|
34d0a602d9 | ||
|
|
620b935f96 | ||
|
|
aaa80e81cb | ||
|
|
bbc14378b5 | ||
|
|
04e6b14aa7 | ||
|
|
19512a1250 | ||
|
|
2c7909536b | ||
|
|
e0dd6a4bb7 | ||
|
|
ef35fd03d8 | ||
|
|
714ecbafe3 | ||
|
|
b31ed5f293 | ||
|
|
84441b2dab | ||
|
|
1f93881100 | ||
|
|
1832c960de | ||
|
|
bbd3a805a2 | ||
|
|
9fef2e8fce | ||
|
|
37beb265f1 | ||
|
|
6deb381f32 | ||
|
|
0b48126a5a | ||
|
|
19b345f5e0 | ||
|
|
4064e3e43f | ||
|
|
149ed55bfe | ||
|
|
ceb0f75afa | ||
|
|
aa963110a4 | ||
|
|
0840746aca | ||
|
|
6c91577427 | ||
|
|
32adfddac6 | ||
|
|
a5fa96945f | ||
|
|
17b73dc786 | ||
|
|
d09a89cd80 | ||
|
|
4e3b0dbc41 | ||
|
|
53da6f9e82 | ||
|
|
12df231ada | ||
|
|
cccf23cc9c | ||
|
|
a96f04b6fe | ||
|
|
9566a0aeab | ||
|
|
f2b1cc0744 | ||
|
|
71a74f8864 | ||
|
|
675ca71cc7 | ||
|
|
ccffd75a01 | ||
|
|
c1178591ac | ||
|
|
e70f81cd44 | ||
|
|
bb9d6b4330 | ||
|
|
9a9cdb33f7 | ||
|
|
85096c0c17 | ||
|
|
8d7c0ed090 | ||
|
|
cafba47390 | ||
|
|
6f5ff0c73b | ||
|
|
ba65fda5fb | ||
|
|
25aa5bf01c | ||
|
|
d5f5cd09aa | ||
|
|
ab6941e0a6 | ||
|
|
656e2ba6fe | ||
|
|
d2441d274c | ||
|
|
288958c81b | ||
|
|
28ffa6115c | ||
|
|
8d61293220 | ||
|
|
1630b7c0fd | ||
|
|
312739e522 | ||
|
|
b097247c2d | ||
|
|
de84a4d04b | ||
|
|
838dbf7246 | ||
|
|
8f3c2c8c33 | ||
|
|
32ec75b27c | ||
|
|
477eee337f | ||
|
|
5381da9185 | ||
|
|
dd82e72cd1 | ||
|
|
04fe54d270 | ||
|
|
50348a8e95 | ||
|
|
6130e43d51 | ||
|
|
8ada47c042 | ||
|
|
ff600bfe98 | ||
|
|
28c54cb73f | ||
|
|
4b05a76ed1 | ||
|
|
3ac219e8ae | ||
|
|
c3acbabd05 | ||
|
|
b803dc42b9 | ||
|
|
84e3dc04cd | ||
|
|
5049da0a21 | ||
|
|
5aa1b9a809 | ||
|
|
cc5353d505 | ||
|
|
b9d428f3bb | ||
|
|
ba92464f52 | ||
|
|
3d50528818 | ||
|
|
2076ecc2bf | ||
|
|
1a553e6f2d | ||
|
|
7c67bf5c93 | ||
|
|
0230c5802d | ||
|
|
abd0235f2f | ||
|
|
52b0781eee | ||
|
|
16af17229a | ||
|
|
29cd9e7692 | ||
|
|
12b6ae2d44 | ||
|
|
f1ecbcd37d | ||
|
|
596f2c86a0 | ||
|
|
bd517961c3 | ||
|
|
101d53394c | ||
|
|
5cf0d8b280 | ||
|
|
f35404581b | ||
|
|
c555ab4b4e | ||
|
|
915e8e6521 | ||
|
|
db6bfc5f8a | ||
|
|
2ff11c4166 | ||
|
|
e7e899c528 | ||
|
|
eaf4aeb78f | ||
|
|
ba648025fd | ||
|
|
868475b04f | ||
|
|
81d22e5f3b | ||
|
|
8e8161302d | ||
|
|
f7b2ba3785 | ||
|
|
c5a338c870 | ||
|
|
9016f7a641 | ||
|
|
e8b268a0af | ||
|
|
2840140786 | ||
|
|
f6885af31f | ||
|
|
057e137ede | ||
|
|
70b121b175 | ||
|
|
a8f827cab3 | ||
|
|
7511caa3da | ||
|
|
864d902112 | ||
|
|
1ece522010 | ||
|
|
99723bbacb | ||
|
|
608901719e | ||
|
|
a5d66b1478 | ||
|
|
adfc562def | ||
|
|
ba16147be4 | ||
|
|
ddc02a78a0 | ||
|
|
e49bbfbe1f | ||
|
|
ee89196671 | ||
|
|
b04aa79797 | ||
|
|
55e2a3d018 | ||
|
|
88025345b9 | ||
|
|
86898515ce | ||
|
|
7965aef382 | ||
|
|
c461435cfe | ||
|
|
38fc690dad | ||
|
|
bde4823eb5 | ||
|
|
16ba1edbae | ||
|
|
e8dc0bcbd4 | ||
|
|
124b2e1be9 | ||
|
|
b3d7af2422 | ||
|
|
8fb04b5829 | ||
|
|
7bd562f625 | ||
|
|
f83997d9f9 | ||
|
|
0df4055709 | ||
|
|
bbb7022067 | ||
|
|
80e4016778 | ||
|
|
a5d7753a8d | ||
|
|
66f891dff7 | ||
|
|
688754df16 | ||
|
|
b2379b8cf4 | ||
|
|
808332ba2b | ||
|
|
8aa2167a38 | ||
|
|
d429be1be1 | ||
|
|
22def1157d | ||
|
|
a46973cfa7 | ||
|
|
1c38ed3dcf | ||
|
|
cd907fe60b | ||
|
|
345a7f5d06 | ||
|
|
950bd14ca0 | ||
|
|
308da946ff | ||
|
|
572c33c822 | ||
|
|
1b0eeb47a1 | ||
|
|
07867a1f88 | ||
|
|
7f8c25ea9d | ||
|
|
d608ec850d | ||
|
|
8ec3f86289 | ||
|
|
0ee423540c | ||
|
|
c0dac924b4 | ||
|
|
9987795946 | ||
|
|
74f3ee9206 | ||
|
|
c082f5dbe5 | ||
|
|
0ea3ebf826 | ||
|
|
4f5efe3a3e | ||
|
|
b1d52e29ec | ||
|
|
9dedb98dcb | ||
|
|
5b3aa0f2d7 | ||
|
|
f04dca514b | ||
|
|
9653a59787 | ||
|
|
0a1c65dd81 | ||
|
|
85fea44d82 | ||
|
|
08af3f1781 | ||
|
|
17858ba48e | ||
|
|
16c4a06788 | ||
|
|
a0fe90d2e9 | ||
|
|
51d9fcea12 | ||
|
|
cf3bc8b3d2 | ||
|
|
3b4f13672d | ||
|
|
979b18cbbd | ||
|
|
aeb821c332 | ||
|
|
9b8d7d1231 | ||
|
|
a071ceb425 | ||
|
|
810eb7b0d6 | ||
|
|
30820da804 | ||
|
|
31726d68d9 | ||
|
|
5c02ff34c2 | ||
|
|
ccbac369e0 | ||
|
|
16b6135c10 | ||
|
|
49e08c285b | ||
|
|
b559db4ed4 | ||
|
|
9fd7fe29a2 | ||
|
|
fdb292a182 | ||
|
|
3f5e970e09 | ||
|
|
2b8d085b46 | ||
|
|
baca84f98f | ||
|
|
4a201891d2 | ||
|
|
50150ff96e | ||
|
|
264b01aa43 | ||
|
|
cc8b9e32bd | ||
|
|
6062643c14 | ||
|
|
25fd718557 | ||
|
|
928ca277c2 | ||
|
|
abd81f8076 | ||
|
|
55bf9759da | ||
|
|
6f2d67cd2f | ||
|
|
7363c1cd09 | ||
|
|
38a7a6e104 | ||
|
|
d5987d64d3 | ||
|
|
fda21b626c | ||
|
|
46ce3ce464 | ||
|
|
4b916d7c48 | ||
|
|
25ecc31433 | ||
|
|
0ec2e20641 | ||
|
|
2aa7a6977b | ||
|
|
d050d88f89 | ||
|
|
4c7e878c6c | ||
|
|
c15f8492de | ||
|
|
35422761e4 | ||
|
|
b9e516837f | ||
|
|
31ae1f0d95 | ||
|
|
e334c5ebfc | ||
|
|
6e706da0f4 | ||
|
|
8c67176f3d | ||
|
|
11a429eb99 | ||
|
|
cf083c56a3 | ||
|
|
5b65b239f1 | ||
|
|
826157760d | ||
|
|
08ced09518 | ||
|
|
30a46b2e5f | ||
|
|
af59e1769c | ||
|
|
3338484831 | ||
|
|
82aa07e7b7 | ||
|
|
9bc436271f | ||
|
|
93ae60e5d6 | ||
|
|
68e60eb8a4 | ||
|
|
b5a04df6cd | ||
|
|
6cc04d5e39 | ||
|
|
0f2eadb5e2 | ||
|
|
ee9b44c041 | ||
|
|
7dbdc7763d | ||
|
|
bfc664479f | ||
|
|
85a6fd789d | ||
|
|
36b275be34 | ||
|
|
fcc880c8f7 | ||
|
|
ebe9f3f466 | ||
|
|
e4a2f55de6 | ||
|
|
c34565adef | ||
|
|
db18fcf83e | ||
|
|
ca9f784e67 | ||
|
|
846e79a2b0 | ||
|
|
17598fae79 | ||
|
|
6942ec9a85 | ||
|
|
37e693b91a | ||
|
|
3c96495687 | ||
|
|
785fd2f8ac | ||
|
|
d0a3ad8704 | ||
|
|
12869eaa07 | ||
|
|
2730da52c6 | ||
|
|
dc536d3e4a | ||
|
|
76d4ac5194 | ||
|
|
ad0cab046a | ||
|
|
6390b1669e | ||
|
|
2aaea46322 | ||
|
|
68d498ce30 | ||
|
|
be8f6b7452 | ||
|
|
8cbbe6659d | ||
|
|
eab4c1e0b9 | ||
|
|
898222c41c | ||
|
|
5dacfb665d | ||
|
|
bb0969ede6 | ||
|
|
40a554bc9b | ||
|
|
947f62f278 | ||
|
|
3cc63b8c02 | ||
|
|
9f1d5f8c5a | ||
|
|
62e81f1292 | ||
|
|
013f816c6c | ||
|
|
ddc2469aa3 | ||
|
|
373dc42696 | ||
|
|
4a0f9dbe8e | ||
|
|
4ebfccb17f | ||
|
|
a02f330f2f | ||
|
|
1145e16e15 | ||
|
|
3536ae7170 | ||
|
|
4e92b0777c | ||
|
|
17a2481bb3 | ||
|
|
f5cc9fcd9f | ||
|
|
a2516baa2f | ||
|
|
96b2cf8298 | ||
|
|
9ac0709648 | ||
|
|
cad1a202b1 | ||
|
|
1412249c41 | ||
|
|
11f6238126 | ||
|
|
55afae9ad0 | ||
|
|
e5a90d3bd8 | ||
|
|
4d1f2e4f35 | ||
|
|
3f59bd779b | ||
|
|
b6ab6a5eb0 | ||
|
|
4de92e9ab6 | ||
|
|
36ec50a706 | ||
|
|
8591d58284 | ||
|
|
e1d7671027 | ||
|
|
0dd7ecb830 | ||
|
|
b9823c8daa | ||
|
|
bdfa65a962 | ||
|
|
d9fa4a7e85 | ||
|
|
e4bf2b5799 | ||
|
|
e8f6a27f1e | ||
|
|
83ef4238fa | ||
|
|
cb64c98e9c | ||
|
|
c411730b6b | ||
|
|
237bf7d966 | ||
|
|
84f6c45869 | ||
|
|
bd0740dc42 | ||
|
|
fabb83eddc | ||
|
|
e12b25522c | ||
|
|
abfed9b1f5 | ||
|
|
af341d2dde | ||
|
|
aa75909130 | ||
|
|
0bd78213b6 | ||
|
|
fc0149621e | ||
|
|
a93111d3d1 | ||
|
|
1864229bae | ||
|
|
5617c657b6 | ||
|
|
5296d5f9e7 | ||
|
|
5ea0c06402 | ||
|
|
f55a90224e | ||
|
|
43f4599a42 | ||
|
|
3bc8215b69 | ||
|
|
3476883ee1 | ||
|
|
db589c5d02 | ||
|
|
bef7369dc5 | ||
|
|
aa15676594 | ||
|
|
66156680b6 | ||
|
|
0e38359528 | ||
|
|
374d4aac17 | ||
|
|
7b14da0eb1 | ||
|
|
d9c7ccc6e5 | ||
|
|
ad86f01119 | ||
|
|
6f6380329d | ||
|
|
3ffbb31b34 | ||
|
|
52e8a88abb | ||
|
|
1754d94047 | ||
|
|
830cebff5a | ||
|
|
c6a5bb46ed | ||
|
|
8adf908bc6 | ||
|
|
93f7e9f4de | ||
|
|
19c074d2b4 | ||
|
|
6059f82461 | ||
|
|
ea7fcdfc89 | ||
|
|
00a884b745 | ||
|
|
5346f46c31 | ||
|
|
8f511e95b9 | ||
|
|
40fe162a04 | ||
|
|
f136bb04d6 | ||
|
|
20b488059b | ||
|
|
c92a7f411d | ||
|
|
eb91f2c19d | ||
|
|
1672072921 | ||
|
|
e364c641d0 | ||
|
|
4abeef8300 | ||
|
|
60e95ef346 | ||
|
|
8503344eea | ||
|
|
96e1ce1b52 | ||
|
|
07626ee7b3 | ||
|
|
d02d0632c0 | ||
|
|
04f1820b22 | ||
|
|
c3e6f3aef6 | ||
|
|
bca7ff59fb | ||
|
|
13dfcedcef | ||
|
|
e52cd587fb | ||
|
|
935a12a56e | ||
|
|
55dd98fd3c | ||
|
|
06ea1f505e | ||
|
|
1bf54a839e | ||
|
|
c601bbacd5 | ||
|
|
ad706c95d5 | ||
|
|
c598ed56ae | ||
|
|
1a553fda1b | ||
|
|
472f51257a | ||
|
|
2dedd7c2a4 | ||
|
|
d03ecb5b77 | ||
|
|
95a615f3bc | ||
|
|
dcfe651252 | ||
|
|
b147860910 | ||
|
|
bcc72bb315 | ||
|
|
db2859a235 | ||
|
|
6365a82a06 | ||
|
|
a660985529 | ||
|
|
275a42de8b | ||
|
|
ed66c5a3e2 | ||
|
|
de4de74d33 | ||
|
|
0e9a59ad6c | ||
|
|
b9bc494291 | ||
|
|
78d0c0ec3d | ||
|
|
680f7f4fb5 | ||
|
|
cb0741ad6d | ||
|
|
09afb442c4 | ||
|
|
ab19fa71d6 | ||
|
|
9eeb2ec6fa | ||
|
|
b42a39df90 | ||
|
|
15c2d7c8b2 | ||
|
|
f066c3691d | ||
|
|
6cc0c7f461 | ||
|
|
974f71ab6e | ||
|
|
803315bb42 | ||
|
|
b1f511e187 | ||
|
|
624c5a83c5 | ||
|
|
b1eed62b5c | ||
|
|
6df30b45d7 | ||
|
|
ccb47897ea | ||
|
|
a05325ba7f | ||
|
|
b8aa8a2217 | ||
|
|
9bc53f63a9 | ||
|
|
2e7633971a | ||
|
|
1384666eb9 | ||
|
|
7dfa6a955a | ||
|
|
d89580fd22 | ||
|
|
f27be37970 | ||
|
|
106c9e2293 | ||
|
|
7bc71298be | ||
|
|
c489f7f608 | ||
|
|
af1c3f29a8 | ||
|
|
1939e147a4 | ||
|
|
004a1d5414 | ||
|
|
c2a10ef9bc | ||
|
|
b18ced777e | ||
|
|
2c23adf973 | ||
|
|
01171cbc52 | ||
|
|
aacc4053db | ||
|
|
a601e0a542 | ||
|
|
196cc676d9 | ||
|
|
c3ef25a7a9 | ||
|
|
de1efda513 | ||
|
|
736a5ff99b | ||
|
|
1b7821a87e | ||
|
|
1d5a5e0a6d | ||
|
|
9f2c3e6186 | ||
|
|
6faf0887c3 | ||
|
|
8c8fb9a5b7 | ||
|
|
3e5c4dbe94 | ||
|
|
686c0aee93 | ||
|
|
829243f8b1 | ||
|
|
41de09df24 | ||
|
|
9d4acc9c3a | ||
|
|
10fa57ef52 | ||
|
|
b72b2e98f1 | ||
|
|
4310641b88 | ||
|
|
6cd49ed46c | ||
|
|
3a13b60c06 | ||
|
|
064ea695d5 | ||
|
|
7e94756b30 | ||
|
|
36a255a5cf | ||
|
|
6bff676201 | ||
|
|
f2d12c347f | ||
|
|
e706b3cdba | ||
|
|
3d0bf5c9a4 | ||
|
|
1475b0fce3 | ||
|
|
de31476ed6 | ||
|
|
21669f85ed | ||
|
|
fa9f4ab0ab | ||
|
|
7f5bcdf116 | ||
|
|
ca77c2b86b | ||
|
|
ee32bf5126 | ||
|
|
250729d441 | ||
|
|
d46c6d1cae | ||
|
|
07297eeb2a | ||
|
|
f0d88d3de3 | ||
|
|
60a5906456 | ||
|
|
a018269724 | ||
|
|
2df2dde564 | ||
|
|
933448ad6e | ||
|
|
ddba03d53b | ||
|
|
702c0bd19a | ||
|
|
49287324b3 | ||
|
|
72a234b9bd | ||
|
|
c479ca0058 | ||
|
|
1fcd61aa36 | ||
|
|
cb9213bf8c | ||
|
|
a504ee7e09 | ||
|
|
e08808d5bc | ||
|
|
deb9ab0461 | ||
|
|
8aaaa48840 | ||
|
|
0d93c572bc | ||
|
|
72fac35781 | ||
|
|
f57a484906 | ||
|
|
07e226dac3 | ||
|
|
8b07933e3d | ||
|
|
5b9a3d373e | ||
|
|
f445033fab | ||
|
|
c11efeb1fe | ||
|
|
e8977ebb57 | ||
|
|
a46f20bff7 | ||
|
|
4a2d866fb0 | ||
|
|
23532d6fb4 | ||
|
|
ea9dcf01ec | ||
|
|
8b438fbca3 | ||
|
|
f5334707b5 | ||
|
|
5cb0474789 | ||
|
|
892b48787b | ||
|
|
01eb8d8637 | ||
|
|
bf43df896b | ||
|
|
6ca5eb658d | ||
|
|
6ef38e3483 | ||
|
|
88370d5433 | ||
|
|
1b014ed75a | ||
|
|
41b9a340d8 | ||
|
|
e6978400f5 | ||
|
|
95f9e56d53 | ||
|
|
eadfa9ae0a | ||
|
|
80b9feb37f | ||
|
|
b69b512875 | ||
|
|
5cdb2f787e | ||
|
|
2118a5eea0 | ||
|
|
22f6299fdb | ||
|
|
a4e3f3b499 | ||
|
|
5bf6f42cd7 | ||
|
|
53af3f399a | ||
|
|
d2d9a3c817 | ||
|
|
1581b2ecd8 | ||
|
|
0968b74220 | ||
|
|
2a200d7211 | ||
|
|
9476cc2899 | ||
|
|
5c1fa6db8c | ||
|
|
bee901746d | ||
|
|
7c5b41eec7 | ||
|
|
dc106691e0 | ||
|
|
a5ba27fd3b | ||
|
|
2511f931d9 | ||
|
|
80b36104ef | ||
|
|
2ab00b6e06 | ||
|
|
3fc938f8c5 | ||
|
|
33604d2115 | ||
|
|
691a1db69a | ||
|
|
5b9b6fa61e | ||
|
|
2586439ca4 | ||
|
|
d89ee4fa72 | ||
|
|
43fe55f634 | ||
|
|
40e0784b59 | ||
|
|
56fef70c43 | ||
|
|
96963fede1 | ||
|
|
acfe96c32c | ||
|
|
19dec45819 | ||
|
|
e0cf6e95ef | ||
|
|
52bf78e1fc | ||
|
|
4a90cfec86 | ||
|
|
1378e479b5 | ||
|
|
0ea6776657 | ||
|
|
d1e46d4424 | ||
|
|
271ffc9371 | ||
|
|
7e05deae32 | ||
|
|
65c1ca3fd9 | ||
|
|
d566eb8d63 | ||
|
|
edd633437c | ||
|
|
9b393e474f | ||
|
|
cf157a157a | ||
|
|
8fc95eda5f | ||
|
|
d4ee0dbf15 | ||
|
|
c4936bbd48 | ||
|
|
2d7b3443bc | ||
|
|
c727e9b502 | ||
|
|
d764fef596 | ||
|
|
5113e35bb9 | ||
|
|
9c262a3266 | ||
|
|
dcfc21ba60 | ||
|
|
17ef693ad4 | ||
|
|
233c959d2f | ||
|
|
b0609d40fc | ||
|
|
8002aeb6cc | ||
|
|
80fd35f736 | ||
|
|
d72f604a96 | ||
|
|
2e33b81ce6 | ||
|
|
7e47b13e67 | ||
|
|
e218ae5baf | ||
|
|
5ac7451566 | ||
|
|
8c0e3a58f6 | ||
|
|
69caad4b6c | ||
|
|
994eccc0eb | ||
|
|
d74f1ba9df | ||
|
|
58588da699 | ||
|
|
6bcb797733 | ||
|
|
0d8959325e | ||
|
|
31a4215cab | ||
|
|
d901827448 | ||
|
|
8abda5fb1d | ||
|
|
4050d5e7e3 | ||
|
|
130885344b | ||
|
|
d9f72cc2dc | ||
|
|
d70f277ee6 | ||
|
|
2f02820a56 | ||
|
|
da5f8e5a14 | ||
|
|
6003a5f2e9 | ||
|
|
ede607455b | ||
|
|
f00b73148f | ||
|
|
c1d4bb2597 | ||
|
|
5be4b432dc | ||
|
|
b601e61e52 | ||
|
|
e04eb7db0d | ||
|
|
15b635c021 | ||
|
|
eb87fd5c0a | ||
|
|
cc731d51e2 | ||
|
|
d32be9ac07 | ||
|
|
8903bc749a | ||
|
|
a9a88f29a0 | ||
|
|
b048814b68 | ||
|
|
401fadafec | ||
|
|
047312216f | ||
|
|
4dd4bcef57 | ||
|
|
a4c5892c11 | ||
|
|
65a20f33f1 | ||
|
|
325f2c4c1a | ||
|
|
bb797e2241 | ||
|
|
25dd9ad631 | ||
|
|
e6dd02f9dd | ||
|
|
36594308d3 | ||
|
|
901520e90a | ||
|
|
b5338379c1 | ||
|
|
a94fcddcf3 | ||
|
|
b77d3d3f28 | ||
|
|
e33e92caac | ||
|
|
4617b59056 | ||
|
|
07606c3af3 | ||
|
|
bcce387bb6 | ||
|
|
85a027feeb | ||
|
|
34ef18311c | ||
|
|
6fa0c54586 | ||
|
|
c765b06883 | ||
|
|
505abd69c5 | ||
|
|
8e9fee915b | ||
|
|
7edec0e321 | ||
|
|
91ff69f4e5 | ||
|
|
6491a49d46 | ||
|
|
74c3cfca9b | ||
|
|
91234b2e4f | ||
|
|
fccdec5cdb | ||
|
|
967fe97690 | ||
|
|
2d43d88d60 | ||
|
|
ec849d3257 | ||
|
|
4242c54c88 | ||
|
|
ee7dc02965 | ||
|
|
617010fa56 | ||
|
|
dc41f07f89 | ||
|
|
8fb74f3199 | ||
|
|
850c53b4a8 | ||
|
|
7aea0d76f7 | ||
|
|
4f58008ca3 | ||
|
|
409bbbe31b | ||
|
|
eae06603f3 | ||
|
|
10d7e48296 | ||
|
|
cc7a302746 | ||
|
|
398bce6ecb | ||
|
|
a106011442 | ||
|
|
f42366dd91 | ||
|
|
cd8fc63f58 | ||
|
|
43b079111c | ||
|
|
339358a174 | ||
|
|
f3e4341a27 | ||
|
|
bf133215a6 | ||
|
|
30c4ef1be9 | ||
|
|
2a6784012f | ||
|
|
9a3a07734e | ||
|
|
4028e98820 | ||
|
|
7c28e6c98a | ||
|
|
aeb2d50790 | ||
|
|
eb92039acd | ||
|
|
733ac47e22 | ||
|
|
8ab4d76d42 | ||
|
|
cd93fdaeb0 | ||
|
|
08d8ed86d7 | ||
|
|
7d5733c9d2 | ||
|
|
f45af8c7f4 | ||
|
|
288206f080 | ||
|
|
f1bf649e1d | ||
|
|
2aa3a9a5c5 | ||
|
|
37c5e5344e | ||
|
|
01b1ecb467 | ||
|
|
0f4da3a208 | ||
|
|
0397541084 | ||
|
|
437c1ab7ae | ||
|
|
9defdc6cd5 | ||
|
|
c703a0de99 | ||
|
|
0ad6018ae2 | ||
|
|
ad3376760e | ||
|
|
2e93a9bc0f | ||
|
|
a6f79a48b9 | ||
|
|
1757d18196 | ||
|
|
1a50e66b18 | ||
|
|
6d36423c18 | ||
|
|
8ab980695b | ||
|
|
96656e273d | ||
|
|
a60aeb08c3 | ||
|
|
8a1e9678ef | ||
|
|
07968d0824 | ||
|
|
7e8eecc0ab | ||
|
|
94816937d7 | ||
|
|
b594a52399 | ||
|
|
554027e555 | ||
|
|
7523a05b3e | ||
|
|
ce2d302bd6 | ||
|
|
52f6ecab8b | ||
|
|
85fbadef2e | ||
|
|
2eded550d1 | ||
|
|
2a722ab19a | ||
|
|
f40c8db270 | ||
|
|
46437a3264 | ||
|
|
a17f8ebe1c | ||
|
|
e599e706a7 | ||
|
|
168b5c8f1a | ||
|
|
e2c548f26e | ||
|
|
cee4fb8a1a | ||
|
|
247b3227a4 | ||
|
|
8733ea801c | ||
|
|
571853e8e0 | ||
|
|
c5315f2466 | ||
|
|
375c3a77db | ||
|
|
fa5991704c | ||
|
|
97de94d925 | ||
|
|
a84888ad30 | ||
|
|
f2bcd752e7 | ||
|
|
53888a65c3 | ||
|
|
fa482fe079 | ||
|
|
bd1fc9c1db | ||
|
|
6fc93be747 | ||
|
|
355b80901b | ||
|
|
294cce62f9 | ||
|
|
d7e614a9d4 | ||
|
|
b45c0a9a51 | ||
|
|
f3ab8eec76 | ||
|
|
1385836a70 | ||
|
|
2230b1807e | ||
|
|
389408ba5d | ||
|
|
85ef95352b | ||
|
|
f7e3409da6 | ||
|
|
ae0701f11b | ||
|
|
fe9cc5ace6 | ||
|
|
5704ddf635 | ||
|
|
4e60db95c0 | ||
|
|
641e2108f2 | ||
|
|
f76cb12bc3 | ||
|
|
cafbdc1c12 | ||
|
|
f6d2972ede | ||
|
|
208b2c72b0 | ||
|
|
5c74de5f71 | ||
|
|
070dd05dc8 | ||
|
|
bcda6910a7 | ||
|
|
ee735a8af5 | ||
|
|
7fe44400cc | ||
|
|
6f3926e28a | ||
|
|
9d0e938afe | ||
|
|
d81fd1df9a | ||
|
|
502c8a8d6f | ||
|
|
5bfe565b5b | ||
|
|
99dc06e355 | ||
|
|
3f05bf4817 | ||
|
|
bfc7134f1c | ||
|
|
c85d17a035 | ||
|
|
05feaf25f5 | ||
|
|
d59de7f334 | ||
|
|
b28a04cc59 | ||
|
|
455a1db5cc | ||
|
|
88d3bd4b1d | ||
|
|
0a53d230b0 | ||
|
|
7a73c89384 | ||
|
|
7ea02588f4 | ||
|
|
21ab7908fd | ||
|
|
76dadd9eb5 | ||
|
|
5dca515f0b | ||
|
|
189283e0dd | ||
|
|
30497e9d48 | ||
|
|
7d70010c91 | ||
|
|
6442923c1f | ||
|
|
4eed0b3d8f | ||
|
|
04f5e3afc4 | ||
|
|
676e91ac7c | ||
|
|
5962932698 | ||
|
|
494245ebe6 | ||
|
|
39374aec4c | ||
|
|
aaad277322 | ||
|
|
cb3acfeeb3 | ||
|
|
42c0b3d866 | ||
|
|
0d538b0387 | ||
|
|
fab5c531be | ||
|
|
e25c8f5549 | ||
|
|
358b1b8695 | ||
|
|
5e9159dbad | ||
|
|
8b0c7d7458 | ||
|
|
81bcea8550 | ||
|
|
4fca72b865 | ||
|
|
98761203cb | ||
|
|
9a02e2ede3 | ||
|
|
7c9dea8bed | ||
|
|
3a8da23666 | ||
|
|
5cc658b535 | ||
|
|
8ecb1b5664 | ||
|
|
ead7e668ff | ||
|
|
eaf62079df | ||
|
|
941ef832f3 | ||
|
|
c967f9be34 | ||
|
|
07717c1cb2 | ||
|
|
54c7ef703d | ||
|
|
992e62127c | ||
|
|
36f75c8404 | ||
|
|
1f6fe9a81b | ||
|
|
8d38f1f8d7 | ||
|
|
5e3c3102a6 | ||
|
|
1ae42c6b70 | ||
|
|
83f63333d4 | ||
|
|
51240e1bad | ||
|
|
efb96fa147 | ||
|
|
dce1ed2998 | ||
|
|
a6bee49d9c | ||
|
|
229e26fa2e | ||
|
|
5734f92170 | ||
|
|
83a75598d5 | ||
|
|
fc97434c5b | ||
|
|
683c2eecbe | ||
|
|
b1e1945488 | ||
|
|
cef800df41 | ||
|
|
a28e676920 | ||
|
|
ea3b34d308 | ||
|
|
28b5951129 | ||
|
|
74736c0bbe | ||
|
|
2aa95bf38c | ||
|
|
c05291bb1f | ||
|
|
c8eece7f03 | ||
|
|
b7bed39420 | ||
|
|
91f91a4efe | ||
|
|
a9acfd3fe7 | ||
|
|
aaf560f95a | ||
|
|
a6b16f9fa1 | ||
|
|
f9a3465c6f | ||
|
|
a55067a1c9 | ||
|
|
8dfed719a0 | ||
|
|
d2031cc751 | ||
|
|
d38149be31 | ||
|
|
fcd565c4b6 | ||
|
|
e74811b2bf | ||
|
|
b318d406e9 | ||
|
|
a284db06f5 | ||
|
|
e0e10b71f7 | ||
|
|
5d49bc78d4 | ||
|
|
c6893215f4 | ||
|
|
ddc05160f2 | ||
|
|
6bd4717ad9 | ||
|
|
73585dd0ea | ||
|
|
2c1a71db26 | ||
|
|
b64fbd2430 | ||
|
|
7415686b36 | ||
|
|
3526169494 | ||
|
|
d9098b1255 | ||
|
|
ce47c6dc76 | ||
|
|
cfbef80934 | ||
|
|
3de69fcd73 | ||
|
|
3c95327443 | ||
|
|
8648657e4b | ||
|
|
e9c60b6bb3 | ||
|
|
6ec08108d7 | ||
|
|
9ed23f00fc | ||
|
|
605bd795e7 | ||
|
|
2ba83ebb08 | ||
|
|
0161857789 | ||
|
|
c833359d74 | ||
|
|
bf33a4f4ce | ||
|
|
78cc662c29 | ||
|
|
569c6fedec | ||
|
|
eed6257417 | ||
|
|
01b13b9130 | ||
|
|
6a40c131ac | ||
|
|
b137cdca9b | ||
|
|
785145278b | ||
|
|
6d5181540c | ||
|
|
d521693526 | ||
|
|
c5eaa963e8 | ||
|
|
86e08fc0b7 | ||
|
|
d0a48dc8e1 | ||
|
|
4ec23aa1dc | ||
|
|
a6c5fba558 | ||
|
|
5dce582bc5 | ||
|
|
5024af87a6 | ||
|
|
5e33c06a66 | ||
|
|
12ab509fe7 | ||
|
|
60ae999a07 | ||
|
|
4f624f015a | ||
|
|
3bc2ec8825 | ||
|
|
a3ed92a887 | ||
|
|
149e9e498d | ||
|
|
bd01b5a24f | ||
|
|
cada8b5bb3 | ||
|
|
9eaaede038 | ||
|
|
cd85c6f2bc | ||
|
|
e4998f5ad8 | ||
|
|
4d93f6d900 | ||
|
|
7284e9d210 | ||
|
|
690546a7d6 | ||
|
|
fbf86e8a78 | ||
|
|
0aa95f6015 | ||
|
|
a1c05ca061 | ||
|
|
e1ba4e407f | ||
|
|
a6b90c6a7a | ||
|
|
8f3826e67b | ||
|
|
9f2092d184 | ||
|
|
9c9f63e4ca | ||
|
|
cddf156153 | ||
|
|
80cb295064 | ||
|
|
a1c27b46db | ||
|
|
7657fb8d45 | ||
|
|
8597f736da | ||
|
|
086642a17e | ||
|
|
858a1f55e0 | ||
|
|
a8f778fb34 | ||
|
|
e7bf924ff7 | ||
|
|
81355e7a10 | ||
|
|
2568996690 | ||
|
|
fa3e83fbd8 | ||
|
|
c64b43ae7e | ||
|
|
a358b4cf96 | ||
|
|
579935b64e | ||
|
|
ee1a4305f4 | ||
|
|
7b01e4ee6f | ||
|
|
d224507a75 | ||
|
|
c6d9ab97ec | ||
|
|
1555d8948e | ||
|
|
2c3c7efe8c | ||
|
|
c4daab57eb | ||
|
|
7f22afeb89 | ||
|
|
2823430d65 | ||
|
|
1668923508 | ||
|
|
3f3a9ed279 | ||
|
|
092c81b39c | ||
|
|
3b1e068b5d | ||
|
|
14e1e3c768 | ||
|
|
f4f7d5676a | ||
|
|
7b3a4577cc | ||
|
|
512e225b73 | ||
|
|
52249bfb5d | ||
|
|
0aded9a4da | ||
|
|
c3df7e864a | ||
|
|
c04e2decaf | ||
|
|
5bdc21e6c7 | ||
|
|
858bd446fd | ||
|
|
9ef0eefc55 | ||
|
|
9ced1efe34 | ||
|
|
ac043a42de | ||
|
|
8d7dbdd802 | ||
|
|
05dbcb9956 | ||
|
|
d3a42778d0 | ||
|
|
7aa0ac7b9b | ||
|
|
dd7341586c | ||
|
|
35b13a69eb | ||
|
|
72a885e8a5 | ||
|
|
22d8081884 | ||
|
|
fd84b38268 | ||
|
|
7a0d345ca2 | ||
|
|
6e192ca1a5 | ||
|
|
24f8685ceb | ||
|
|
8170b48dba | ||
|
|
ce159743de | ||
|
|
6143ed2504 | ||
|
|
1e38cfaf5a | ||
|
|
ab3a49f087 | ||
|
|
ecdace453e | ||
|
|
4aa42e3c2b | ||
|
|
48edb88fe6 | ||
|
|
f4fe5f16e9 | ||
|
|
755173396c | ||
|
|
2beb7f0ab9 | ||
|
|
44d3516be2 | ||
|
|
ab8f584c8c | ||
|
|
d32a6c818d | ||
|
|
589a92b3eb | ||
|
|
bf3cd69641 | ||
|
|
25e6cb1de9 | ||
|
|
20fc06c5dc | ||
|
|
832ec1a9a7 | ||
|
|
78bd26211d | ||
|
|
b20e6856b6 | ||
|
|
ff89603e82 | ||
|
|
266e0429ef | ||
|
|
b29271a7d1 | ||
|
|
10188dfba9 | ||
|
|
684e24132a | ||
|
|
14ff4bda29 | ||
|
|
2118ece784 | ||
|
|
d1870dd6cf | ||
|
|
c0f8361e8c | ||
|
|
a885e7f981 | ||
|
|
cc778299af | ||
|
|
8246648f18 | ||
|
|
e204e2e7cf | ||
|
|
f8fc7e5ab4 | ||
|
|
cef3df332e | ||
|
|
ef9e36ad74 | ||
|
|
b9804696fe | ||
|
|
78b124fd57 | ||
|
|
db9b60ff8c | ||
|
|
fa5eb3feba | ||
|
|
556a2d039a | ||
|
|
bfab17b353 | ||
|
|
9dcce61d84 | ||
|
|
a52e067a38 | ||
|
|
62ae0a54c3 | ||
|
|
23d1cba365 | ||
|
|
98df00c0dd | ||
|
|
c5267505f9 | ||
|
|
4b109aa39c | ||
|
|
43e3f84da0 | ||
|
|
2e20f60554 | ||
|
|
9c626542fc | ||
|
|
265ed0a7f7 | ||
|
|
154dfcc797 | ||
|
|
a097d3ae3c | ||
|
|
8ce02c938f | ||
|
|
4a085a558a | ||
|
|
adee1f13b0 | ||
|
|
d68cf0c108 | ||
|
|
a536e69ff8 | ||
|
|
aa81915541 | ||
|
|
5043de261e | ||
|
|
d9ab5ba46a | ||
|
|
2a0a27f00a | ||
|
|
751f4365a9 | ||
|
|
12202ff391 | ||
|
|
6c1b88998e | ||
|
|
85239ebef6 | ||
|
|
06fa66f6ff | ||
|
|
f042bef513 | ||
|
|
ce14d6ad9d | ||
|
|
5bf34a7ad2 | ||
|
|
98b1d72aa4 | ||
|
|
1821f0e587 | ||
|
|
d1a5b58d03 | ||
|
|
da191d33c2 | ||
|
|
6100288a2f | ||
|
|
8264bfc23f | ||
|
|
843cb007e5 | ||
|
|
c1fcf34d6a | ||
|
|
219b6b5b54 | ||
|
|
7784bcf1a4 | ||
|
|
6c0814bde7 | ||
|
|
dfea415aa3 | ||
|
|
95da5226fb | ||
|
|
af8ab471e7 | ||
|
|
2dd487db73 | ||
|
|
db3342e865 | ||
|
|
3394ae40b3 | ||
|
|
5b88923783 | ||
|
|
7091fd6cbc | ||
|
|
94e17b8685 | ||
|
|
3935dae9c2 | ||
|
|
e8c1cfc107 | ||
|
|
fee4bc3993 | ||
|
|
7b551501a2 | ||
|
|
827ce2a2ce | ||
|
|
f31d74d66d | ||
|
|
c3e475af74 | ||
|
|
ed3f76dea7 | ||
|
|
f946a2d503 | ||
|
|
b86ce9ae9a | ||
|
|
76715e219a | ||
|
|
184f22e538 | ||
|
|
957de399cd | ||
|
|
fa2714690d | ||
|
|
ca456f8868 | ||
|
|
fbec4a1d1d | ||
|
|
af434517be | ||
|
|
732ec6f76e | ||
|
|
8e05cacf31 | ||
|
|
4ba9e23bc7 | ||
|
|
88d8a9cb71 | ||
|
|
972a6a41b8 | ||
|
|
47fefae471 | ||
|
|
9c2e7adbd6 | ||
|
|
1ee974b3ec | ||
|
|
6eadfb8d13 | ||
|
|
8de2f14ce9 | ||
|
|
5aa9f95636 | ||
|
|
e0e7310024 | ||
|
|
e5e467b257 | ||
|
|
55fa86d7be | ||
|
|
a9465eeffc | ||
|
|
0797b57bd0 | ||
|
|
cb2393abcf | ||
|
|
4db6d65b08 | ||
|
|
3879880554 | ||
|
|
edfc9943ef | ||
|
|
6692cbb192 | ||
|
|
62f5a16cdf | ||
|
|
3b28b7bd26 | ||
|
|
1b9d89a7e6 | ||
|
|
c7404cc041 | ||
|
|
a4c588562c | ||
|
|
3e88c1ef02 | ||
|
|
3374980bbc | ||
|
|
3ba6a9a47a | ||
|
|
193d318e2f | ||
|
|
dfd575d062 | ||
|
|
f6e0636553 | ||
|
|
a4a757bbad | ||
|
|
baf63af68c | ||
|
|
9180900d52 | ||
|
|
f3aa113380 | ||
|
|
e8d88ed790 | ||
|
|
2d40a4fa61 | ||
|
|
0f77c7fb9f | ||
|
|
83c3f45a29 | ||
|
|
f84e129361 | ||
|
|
bf86a0f8ef | ||
|
|
e7cbb5780b | ||
|
|
4a4b1ae156 | ||
|
|
63e97ee535 | ||
|
|
b8817780f3 | ||
|
|
530c4d4c63 | ||
|
|
6a1b482c86 | ||
|
|
d530ba1126 | ||
|
|
bcaecff14d | ||
|
|
d568a6aca5 | ||
|
|
77fda75841 | ||
|
|
92587276da | ||
|
|
b2dfaa494e | ||
|
|
b231200eb7 | ||
|
|
4c1ac6ad54 | ||
|
|
d345f87d53 | ||
|
|
3ef854719d | ||
|
|
17cd5516a1 | ||
|
|
a117b57ec9 | ||
|
|
925f0be202 | ||
|
|
9ffcf24477 | ||
|
|
bef1b25962 | ||
|
|
05de05abe7 | ||
|
|
54e3b3db4f | ||
|
|
21c2208de6 | ||
|
|
41cd4c15fd | ||
|
|
714b50f54b | ||
|
|
2ac28f401c | ||
|
|
ba5ae63e87 | ||
|
|
2e1928a4eb | ||
|
|
9a02327a2d | ||
|
|
8c0394eea8 | ||
|
|
085069e600 | ||
|
|
e30901a8c4 | ||
|
|
5d2434ce92 | ||
|
|
398a848925 | ||
|
|
dee952edfa | ||
|
|
1ada89da2a | ||
|
|
02d10bc877 | ||
|
|
1046fc1eea | ||
|
|
b5e86c2482 | ||
|
|
2ab7549af6 | ||
|
|
85435303c8 | ||
|
|
51eccf208f | ||
|
|
b27463bccd | ||
|
|
1d613c24af | ||
|
|
cc22bb4175 | ||
|
|
6a084edba7 | ||
|
|
e9b3f54f7c | ||
|
|
ee4b1850bb | ||
|
|
49a0e9c414 | ||
|
|
56ba46b2bc | ||
|
|
cf20acf289 | ||
|
|
64ff1da3e4 | ||
|
|
8e4156532d | ||
|
|
6e32042c52 | ||
|
|
e551fa234e | ||
|
|
15aec67505 | ||
|
|
03409fb772 | ||
|
|
7fab127af3 | ||
|
|
b4b66ce74f | ||
|
|
fff0d30a9a | ||
|
|
2c0619a13a | ||
|
|
2601187207 | ||
|
|
8d7aa4baad | ||
|
|
6eaf938a14 | ||
|
|
6d42bab835 | ||
|
|
2cd5f2033e | ||
|
|
068dee8a06 | ||
|
|
85b1c8b043 | ||
|
|
a955307239 | ||
|
|
dea117397b | ||
|
|
ac8dee35d0 | ||
|
|
46a5c99978 | ||
|
|
77d2cc5222 | ||
|
|
c4dee9c081 | ||
|
|
4a2029781a | ||
|
|
6cde876c44 | ||
|
|
9adb899d09 | ||
|
|
8c2dd5a6b5 | ||
|
|
73af9ae6cf | ||
|
|
783f95590f | ||
|
|
d5399de251 | ||
|
|
b94907a1fa | ||
|
|
40fcf103bd | ||
|
|
7f230788d0 | ||
|
|
f0445587cf | ||
|
|
a089216ae7 | ||
|
|
150d744512 | ||
|
|
e25887d5ca | ||
|
|
c0e66dc8d3 | ||
|
|
61ab763c07 | ||
|
|
86f29918c8 | ||
|
|
af335c7be5 | ||
|
|
2d11c4b2fe | ||
|
|
6fd15f62dc | ||
|
|
ca787ba372 | ||
|
|
aa65dc9fbd | ||
|
|
ff47f2ee43 | ||
|
|
5be59d3ade | ||
|
|
aa74e86069 | ||
|
|
a915561735 | ||
|
|
9f1edee15f | ||
|
|
a17a987cb8 | ||
|
|
db9268bb08 | ||
|
|
f064ac567e | ||
|
|
17504bb39a | ||
|
|
ad77d9eb14 | ||
|
|
558e2166ba | ||
|
|
c71656ab19 | ||
|
|
23cf9b8443 | ||
|
|
44b78ad38d | ||
|
|
386c0d6e1a | ||
|
|
046ee8050f | ||
|
|
1154d87f41 | ||
|
|
0c16a79a37 | ||
|
|
f177d69279 | ||
|
|
a4368ea2d1 | ||
|
|
675d30712d | ||
|
|
209801cac1 | ||
|
|
9c57272ef9 | ||
|
|
01f22b3870 | ||
|
|
6ade85f76e | ||
|
|
0349b620cd | ||
|
|
6001a4462e | ||
|
|
0d853f8c4b | ||
|
|
e5277be072 | ||
|
|
cc246efa46 | ||
|
|
2fe95a276d |
57
.distr
Normal file
57
.distr
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
README
|
||||||
|
CHANGES
|
||||||
|
Copyright
|
||||||
|
pm
|
||||||
|
pmfile
|
||||||
|
config.pm
|
||||||
|
|
||||||
|
h
|
||||||
|
modules/h
|
||||||
|
|
||||||
|
first
|
||||||
|
util/data
|
||||||
|
util/LLgen
|
||||||
|
|
||||||
|
modules/src/alloc
|
||||||
|
modules/src/assert
|
||||||
|
modules/src/system
|
||||||
|
modules/src/string
|
||||||
|
modules/src/read_em
|
||||||
|
modules/src/em_code
|
||||||
|
modules/src/em_mes
|
||||||
|
modules/src/print
|
||||||
|
modules/src/object
|
||||||
|
modules/src/idf
|
||||||
|
modules/src/input
|
||||||
|
modules/src/flt_arith
|
||||||
|
|
||||||
|
util/amisc
|
||||||
|
util/cmisc
|
||||||
|
util/ack
|
||||||
|
lib/descr/fe
|
||||||
|
util/arch
|
||||||
|
#util/cpp
|
||||||
|
util/cgg
|
||||||
|
util/ncgg
|
||||||
|
util/misc
|
||||||
|
util/opt
|
||||||
|
util/ego
|
||||||
|
util/topgen
|
||||||
|
util/led
|
||||||
|
|
||||||
|
lang/cem
|
||||||
|
lang/pc
|
||||||
|
lang/m2
|
||||||
|
#lang/occam
|
||||||
|
#lang/basic
|
||||||
|
|
||||||
|
mach/proto
|
||||||
|
mach/i80
|
||||||
|
mach/i86
|
||||||
|
mach/i386
|
||||||
|
|
||||||
|
plat/cpm
|
||||||
|
plat/pc86
|
||||||
|
plat/linux386
|
||||||
|
|
||||||
|
examples
|
||||||
276
Action
Normal file
276
Action
Normal file
@ -0,0 +1,276 @@
|
|||||||
|
name "System definition"
|
||||||
|
dir first
|
||||||
|
action ack_sys
|
||||||
|
failure "You have to run the shell script first/first"
|
||||||
|
fatal
|
||||||
|
end
|
||||||
|
name "Manual pages"
|
||||||
|
dir man
|
||||||
|
end
|
||||||
|
! name "EM definition"
|
||||||
|
! dir etc
|
||||||
|
! end
|
||||||
|
name "EM definition library"
|
||||||
|
dir util/data
|
||||||
|
end
|
||||||
|
name "C utilities"
|
||||||
|
dir util/cmisc
|
||||||
|
end
|
||||||
|
name "Yacc parser generator"
|
||||||
|
dir util/byacc
|
||||||
|
end
|
||||||
|
name "Flex lexical analyzer generator"
|
||||||
|
dir util/flex
|
||||||
|
action "make firstinstall && make clean"
|
||||||
|
end
|
||||||
|
name "Include files for modules"
|
||||||
|
dir modules/h
|
||||||
|
end
|
||||||
|
name "Modules"
|
||||||
|
dir modules/src
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
! name "LL(1) Parser generator"
|
||||||
|
! dir util/LLgen
|
||||||
|
! action "make firstinstall && make clean"
|
||||||
|
! end
|
||||||
|
name "C preprocessor"
|
||||||
|
dir util/cpp
|
||||||
|
end
|
||||||
|
name "Peephole optimizer libraries"
|
||||||
|
dir modules/src/em_opt
|
||||||
|
end
|
||||||
|
name "ACK object utilities"
|
||||||
|
dir util/amisc
|
||||||
|
end
|
||||||
|
name "Encode/Decode"
|
||||||
|
dir util/misc
|
||||||
|
end
|
||||||
|
name "Shell files in bin"
|
||||||
|
dir util/shf
|
||||||
|
end
|
||||||
|
name "EM assembler"
|
||||||
|
dir util/ass
|
||||||
|
end
|
||||||
|
name "EM Peephole optimizer"
|
||||||
|
dir util/opt
|
||||||
|
end
|
||||||
|
name "EM Global optimizer"
|
||||||
|
dir util/ego
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "ACK archiver"
|
||||||
|
dir util/arch
|
||||||
|
end
|
||||||
|
name "Program 'ack'"
|
||||||
|
dir util/ack
|
||||||
|
end
|
||||||
|
name "Bootstrap for backend tables"
|
||||||
|
dir util/cgg
|
||||||
|
end
|
||||||
|
name "Bootstrap for newest form of backend tables"
|
||||||
|
dir util/ncgg
|
||||||
|
end
|
||||||
|
name "Bootstrap for code expanders"
|
||||||
|
dir util/ceg
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "LED link editor"
|
||||||
|
dir util/led
|
||||||
|
end
|
||||||
|
name "TOPGEN target optimizer generator"
|
||||||
|
dir util/topgen
|
||||||
|
end
|
||||||
|
name "C frontend"
|
||||||
|
dir lang/cem/cemcom
|
||||||
|
end
|
||||||
|
name "ANSI-C frontend"
|
||||||
|
dir lang/cem/cemcom.ansi
|
||||||
|
end
|
||||||
|
name "ANSI-C preprocessor"
|
||||||
|
dir lang/cem/cpp.ansi
|
||||||
|
end
|
||||||
|
name "ANSI-C header files"
|
||||||
|
dir lang/cem/libcc.ansi
|
||||||
|
end
|
||||||
|
name "LINT C program checker"
|
||||||
|
dir lang/cem/lint
|
||||||
|
end
|
||||||
|
name "EM definition lint-library"
|
||||||
|
action "make lintlib"
|
||||||
|
dir util/data
|
||||||
|
end
|
||||||
|
name "Modules lint libraries"
|
||||||
|
dir modules/src
|
||||||
|
indir "Action.lint"
|
||||||
|
end
|
||||||
|
name "Global optimizer lint libraries"
|
||||||
|
dir util/ego/share
|
||||||
|
action "make lintlib"
|
||||||
|
end
|
||||||
|
name "Pascal frontend"
|
||||||
|
dir lang/pc/comp
|
||||||
|
end
|
||||||
|
name "Basic frontend"
|
||||||
|
dir lang/basic/src
|
||||||
|
end
|
||||||
|
name "Occam frontend"
|
||||||
|
dir lang/occam/comp
|
||||||
|
end
|
||||||
|
name "Modula-2 frontend"
|
||||||
|
dir lang/m2/comp
|
||||||
|
end
|
||||||
|
name "Modula-2 definition modules"
|
||||||
|
dir lang/m2/libm2
|
||||||
|
end
|
||||||
|
name "Modula-2 makefile generator"
|
||||||
|
dir lang/m2/m2mm
|
||||||
|
end
|
||||||
|
name "Fortran to C compiler"
|
||||||
|
dir lang/fortran/comp
|
||||||
|
end
|
||||||
|
name "EM interpreter in C"
|
||||||
|
dir util/int
|
||||||
|
end
|
||||||
|
name "Symbolic debugger"
|
||||||
|
dir util/grind
|
||||||
|
end
|
||||||
|
name "Intel 8086 support"
|
||||||
|
dir mach/i86
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Intel 80286 support for Xenix"
|
||||||
|
dir mach/xenix3
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Intel 80386 support for Xenix 386 System V"
|
||||||
|
dir mach/i386
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "MSC6500 support"
|
||||||
|
dir mach/6500
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Motorola 6800 support"
|
||||||
|
dir mach/6800
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Motorola 6805 support"
|
||||||
|
dir mach/6805
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Motorola 6809 support"
|
||||||
|
dir mach/6809
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Intel 8080 support"
|
||||||
|
dir mach/i80
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "2-2 Interpreter support"
|
||||||
|
dir mach/em22
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "2-4 Interpreter support"
|
||||||
|
dir mach/em24
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "4-4 Interpreter support"
|
||||||
|
dir mach/em44
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Motorola 68000 2-4 support"
|
||||||
|
dir mach/m68k2
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Motorola 68000 4-4 support"
|
||||||
|
dir mach/m68k4
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "NS16032 support"
|
||||||
|
dir mach/ns
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "PDP 11 support"
|
||||||
|
dir mach/pdp
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "PMDS support"
|
||||||
|
dir mach/pmds
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "PMDS 4/4 support"
|
||||||
|
dir mach/pmds4
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Signetics 2650 support"
|
||||||
|
dir mach/s2650
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Vax 4-4 support"
|
||||||
|
dir mach/vax4
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "M68020 System V/68 support"
|
||||||
|
dir mach/m68020
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Sun 3 M68020 support"
|
||||||
|
dir mach/sun3
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Sun 4 SPARC SunOs 4 support"
|
||||||
|
dir mach/sparc
|
||||||
|
system "sparc|sparc_solaris"
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Sun 4 SPARC Solaris support"
|
||||||
|
dir mach/sparc_solaris
|
||||||
|
system "sparc_solaris"
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Sun 2 M68000 support"
|
||||||
|
dir mach/sun2
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Mantra M68000 System V.0 support"
|
||||||
|
dir mach/mantra
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "PC Minix support"
|
||||||
|
dir mach/minix
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Atari ST Minix support"
|
||||||
|
dir mach/minixST
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Z80 support"
|
||||||
|
dir mach/z80
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Zilog Z8000 support"
|
||||||
|
dir mach/z8000
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Acorn Archimedes support"
|
||||||
|
dir mach/arm
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Documentation"
|
||||||
|
dir doc
|
||||||
|
end
|
||||||
|
name "Motorola 68000 interpreters"
|
||||||
|
system "m68*|sun*"
|
||||||
|
dir mach/mantra/int
|
||||||
|
end
|
||||||
|
name "Fast compilers"
|
||||||
|
system "m68020|sun3|i386|vax*"
|
||||||
|
dir fast
|
||||||
|
indir
|
||||||
|
end
|
||||||
|
name "Fast cc-compatible C compiler"
|
||||||
|
system "sun3|vax*"
|
||||||
|
dir fcc
|
||||||
|
indir
|
||||||
|
end
|
||||||
35
CHANGES
Normal file
35
CHANGES
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
# $Source$
|
||||||
|
# $State$
|
||||||
|
# $Revision$
|
||||||
|
|
||||||
|
6.0pre4
|
||||||
|
|
||||||
|
Fixed some minor bit-rotting issues that were preventing compilation on
|
||||||
|
modern Linux systems.
|
||||||
|
|
||||||
|
6.0pre3
|
||||||
|
|
||||||
|
Added the cpm platform. Made some optimisations to the i80 code generator,
|
||||||
|
including getting topgen up and running and adding some peephole optimiser
|
||||||
|
rules. Fixed loads of bugs in ego so that it now works on platforms that
|
||||||
|
support it (pc86 and linux386). Made the floating point work on platforms
|
||||||
|
that support it (pc86 and linux386 again). Made stdint.h work. Lots and lots
|
||||||
|
of bugfixes and tweaks everywhere.
|
||||||
|
|
||||||
|
6.0pre2
|
||||||
|
|
||||||
|
Much simplified the syscall interface by disabling libmon and instead
|
||||||
|
calling the syscalls directly. Disabled the K&R C compiler and libc because
|
||||||
|
it doesn't actually gain us anything and has a high maintenance load --- the
|
||||||
|
ANSI C compiler works fine with K&R C. Adapted the rest of the system to
|
||||||
|
build with the ANSI C compiler. Rewrote the pc86 syscall interface and added
|
||||||
|
linux386 support, using the i386 code generator. Lots and lots of bugfixes
|
||||||
|
and tweaks everywhere.
|
||||||
|
|
||||||
|
6.0pre1
|
||||||
|
|
||||||
|
First working version of the 6.0 release stream. Working frontends: both C
|
||||||
|
compilers, Pascal, Modula-2, Basic and Occam. Working backends: i86. Working
|
||||||
|
platforms: pc86, the very noddy testbed setup that produces floppy disk
|
||||||
|
images.
|
||||||
|
|
||||||
32
Copyright
Normal file
32
Copyright
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
Copyright (c) 1987, 1990, 1993, 2005 Vrije Universiteit, Amsterdam, The Netherlands.
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use of the Amsterdam Compiler Kit in source and
|
||||||
|
binary forms, with or without modification, are permitted provided
|
||||||
|
that the following conditions are met:
|
||||||
|
|
||||||
|
* Redistributions of source code must retain the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
* Redistributions in binary form must reproduce the above
|
||||||
|
copyright notice, this list of conditions and the following
|
||||||
|
disclaimer in the documentation and/or other materials provided
|
||||||
|
with the distribution.
|
||||||
|
|
||||||
|
* Neither the name of Vrije Universiteit nor the names of the
|
||||||
|
software authors or contributors may be used to endorse or
|
||||||
|
promote products derived from this software without specific
|
||||||
|
prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS, AUTHORS, AND
|
||||||
|
CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
||||||
|
INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||||
|
IN NO EVENT SHALL VRIJE UNIVERSITEIT OR ANY AUTHORS OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
|
||||||
|
BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
|
WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
|
||||||
|
OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
|
||||||
|
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
45
NEW
Normal file
45
NEW
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
This is ACK distribution 5.6.
|
||||||
|
|
||||||
|
This is a minor update of 5.5, the last public release from Vrije University.
|
||||||
|
Only minor changes have been made to make the system build on modern
|
||||||
|
platforms.
|
||||||
|
|
||||||
|
The NEW document from the previous release follows.
|
||||||
|
|
||||||
|
David Given
|
||||||
|
dg@cowlark.com 2005-06-24
|
||||||
|
|
||||||
|
-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
The only addition with respect to the 5th ACK distribution is the support
|
||||||
|
for Solaris 2 on SPARCs. It also contains many bug fixes.
|
||||||
|
|
||||||
|
Notes for the 5th ACK distribution:
|
||||||
|
|
||||||
|
It is not wise to mix files created by the previous version of the Kit
|
||||||
|
with files belonging to this version, although that might sometimes work.
|
||||||
|
Many problems with the previous distribution have been fixed.
|
||||||
|
The major additions are:
|
||||||
|
|
||||||
|
- an ANSI C compiler
|
||||||
|
- a LINT C program checker, both non-ansi and ansi
|
||||||
|
- an Intel 80386 back-end
|
||||||
|
- a SPARC code expander
|
||||||
|
- a source level debugger for Pascal, Modula-2, C, and ANSI C
|
||||||
|
- an Acorn Archimedes back-end
|
||||||
|
- code-expanders for VAX, Intel 80386 and Motorola M68020 processors,
|
||||||
|
and very fast Pascal, Modula-2, ANSI C, and C compilers constructed
|
||||||
|
using these code expanders
|
||||||
|
- a cc-compatible very fast C compiler for SUN-3 and VAX.
|
||||||
|
|
||||||
|
Also added, but not part of the Kit proper are
|
||||||
|
- flex: a lexical analyzer generator
|
||||||
|
- byacc: yacc-clone by UCB
|
||||||
|
- f2c: a Fortran to C compiler by AT&T.
|
||||||
|
|
||||||
|
See the ACK installation manual for their copyright notices.
|
||||||
|
|
||||||
|
--
|
||||||
|
Ceriel Jacobs, Dept. of Mathematics and Computer Science, Vrije Universiteit,
|
||||||
|
De Boelelaan 1081a, 1081 HV Amsterdam, The Netherlands
|
||||||
|
Email: ceriel@cs.vu.nl Fax: +31 20 6427705
|
||||||
170
README
Normal file
170
README
Normal file
@ -0,0 +1,170 @@
|
|||||||
|
THE AMSTERDAM COMPILER KIT V6.0pre4
|
||||||
|
===================================
|
||||||
|
|
||||||
|
© 1987-2005 Vrije Universiteit, Amsterdam
|
||||||
|
2010-08-08
|
||||||
|
|
||||||
|
|
||||||
|
INTRODUCTION
|
||||||
|
============
|
||||||
|
|
||||||
|
The Amsterdam Compiler Kit is a complete compiler toolchain consisting of
|
||||||
|
front end compilers for a number of different languages, code generators,
|
||||||
|
support libraries, and all the tools necessary to go from source code to
|
||||||
|
executable on any of the platforms it supports.
|
||||||
|
|
||||||
|
This is an early prerelease of the apocryphal version 6.0 release. Not a
|
||||||
|
lot is supported, the build mechanism needs work, and a lot of things are
|
||||||
|
probably broken. However, what's there should be sufficient to get things
|
||||||
|
done and to evaluate how the full 6.0 release should work.
|
||||||
|
|
||||||
|
|
||||||
|
SUPPORT
|
||||||
|
=======
|
||||||
|
|
||||||
|
Languages:
|
||||||
|
|
||||||
|
ANSI C, Pascal, Modula 2. K&R is supported via the ANSI C compiler.
|
||||||
|
|
||||||
|
Platforms:
|
||||||
|
|
||||||
|
pc86 produces bootable floppy disk images for 8086 PCs
|
||||||
|
linux386 produces ELF executables for PC Linux systems
|
||||||
|
cpm produces i80 CP/M .COM files
|
||||||
|
|
||||||
|
|
||||||
|
INSTALLATION
|
||||||
|
============
|
||||||
|
|
||||||
|
The version 6.0 build mechanism has been completely rewritten and is based
|
||||||
|
around the Prime Mover build tool (see http://primemover.sf.net for more
|
||||||
|
information). Installation ought to be fairly straightforward.
|
||||||
|
|
||||||
|
Requirements:
|
||||||
|
|
||||||
|
- an ANSI C compiler. Currently, I'm afraid, it's hard-coded to use gcc.
|
||||||
|
To change, try changing the variable definitions in first/c.pm. This also
|
||||||
|
needs to be available as 'cc' from the shell.
|
||||||
|
|
||||||
|
- about 20MB free in /tmp (or some other temporary directory).
|
||||||
|
|
||||||
|
- about 6MB in the target directory.
|
||||||
|
|
||||||
|
Instructions:
|
||||||
|
|
||||||
|
- edit config.pm. There's a small section at the top containing some editable
|
||||||
|
variables. Probably the only one you may want to edit is PREFIX, which
|
||||||
|
changes where the ACK installs to.
|
||||||
|
|
||||||
|
- Run:
|
||||||
|
|
||||||
|
./pm configure
|
||||||
|
|
||||||
|
...from the command line. This will write out a configuration file.
|
||||||
|
|
||||||
|
- Run:
|
||||||
|
|
||||||
|
./pm
|
||||||
|
|
||||||
|
...from the command line. This will actually do the build. This takes
|
||||||
|
about two minutes on my 1.6GHz Athlon Linux machine and about 30 on my
|
||||||
|
166MHz Pentium OpenBSD machine.
|
||||||
|
|
||||||
|
- Run:
|
||||||
|
|
||||||
|
./pm install
|
||||||
|
|
||||||
|
...from the command line (possibly with sudo). This will install the built
|
||||||
|
ACK into whatever directory you nominated in PREFIX.
|
||||||
|
|
||||||
|
The ACK should now be ready to use.
|
||||||
|
|
||||||
|
|
||||||
|
USAGE
|
||||||
|
=====
|
||||||
|
|
||||||
|
Currently I haven't sorted out all the documentation --- it's supplied in the
|
||||||
|
distribution, but not all of it gets installed yet --- so here is a quickstart
|
||||||
|
guide.
|
||||||
|
|
||||||
|
The main command to use is 'ack'. This invokes the compiler and the linker.
|
||||||
|
Some useful options include:
|
||||||
|
|
||||||
|
-m<platform> build for the specified platform
|
||||||
|
-o <file> specifies the output file
|
||||||
|
-c produce a .o file
|
||||||
|
-c.s produce a .s assembly file
|
||||||
|
-O enable optimisation
|
||||||
|
-ansi compile ANSI C (when using the C compiler)
|
||||||
|
<file> build file
|
||||||
|
|
||||||
|
ack figures out which language to use from the file extension:
|
||||||
|
|
||||||
|
.c C (ANSI or K&R)
|
||||||
|
.b Basic
|
||||||
|
.mod Modula-2
|
||||||
|
.ocm Occam 1
|
||||||
|
.p Pascal
|
||||||
|
.o object files
|
||||||
|
.s assembly files
|
||||||
|
|
||||||
|
For further information, see the man page (which actually does get
|
||||||
|
installed, but is rather out of date).
|
||||||
|
|
||||||
|
There are some (known working) example programs in the 'examples' directory.
|
||||||
|
A sample command line is:
|
||||||
|
|
||||||
|
ack -mlinux386 -O examples/paranoia.c
|
||||||
|
|
||||||
|
|
||||||
|
GOTCHAS
|
||||||
|
=======
|
||||||
|
|
||||||
|
There are some things you should be aware of.
|
||||||
|
|
||||||
|
- Look at plat/<PLATFORMNAME>/README for information about the two supported
|
||||||
|
platforms.
|
||||||
|
|
||||||
|
- The library support is fairly limited; for C, it's at roughly the ANSI C
|
||||||
|
level, and for the other languages it's similar.
|
||||||
|
|
||||||
|
- When compiling languages other than C, the ACK will usually look at the
|
||||||
|
first character of the file. If it's a #, then the file will be run through
|
||||||
|
the C preprocessor anyway.
|
||||||
|
|
||||||
|
- BSD systems may need to up the number of file descriptors (e.g.
|
||||||
|
'ulimit -n 200') before the ACK will compile.
|
||||||
|
|
||||||
|
- The ACK uses its own .o format. You won't be able to mix the ACK's object
|
||||||
|
files and another compiler's.
|
||||||
|
|
||||||
|
|
||||||
|
DISCLAIMER
|
||||||
|
==========
|
||||||
|
|
||||||
|
The ACK is mature, well-tested software, but the environment in which it was
|
||||||
|
developed for and tested under is rather different from that available on
|
||||||
|
today's machines. There will probably be little in the way of logical bugs,
|
||||||
|
but there may be many compilation and API bugs.
|
||||||
|
|
||||||
|
If you wish to use the ACK, *please* join the mailing list. We are interested
|
||||||
|
in any reports of success and particularly, failure. If it does fail for you,
|
||||||
|
we would love to know why, in as much detail as possible. Bug fixes are even
|
||||||
|
more welcome.
|
||||||
|
|
||||||
|
The ACK is licensed under a BSD-like license. Please see the 'Copyright' file
|
||||||
|
for the full text.
|
||||||
|
|
||||||
|
You can find the mailing list on the project's web site:
|
||||||
|
|
||||||
|
http://tack.sourceforge.net/
|
||||||
|
|
||||||
|
Please enjoy.
|
||||||
|
|
||||||
|
David Given (dtrg on Sourceforge)
|
||||||
|
dg@cowlark.com
|
||||||
|
2010-08-08
|
||||||
|
|
||||||
|
# $Source$
|
||||||
|
# $State$
|
||||||
|
# $Revision$
|
||||||
20
TODO
Normal file
20
TODO
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
# $Source$
|
||||||
|
# $State$
|
||||||
|
|
||||||
|
This file contains things that I have noticed need fixing, but have not
|
||||||
|
yet been fixed. Everything here should be reasonably low priority. Some
|
||||||
|
bugs have been bodged around to make things work; these are all marked in
|
||||||
|
the source with FIXME tags.
|
||||||
|
|
||||||
|
|
||||||
|
* util/int needs to be rewritten to emulate sgtty with termios; look for
|
||||||
|
FIXMEs.
|
||||||
|
|
||||||
|
* mach/i80/dl/nascom.c needs to be rewritten to use termios, not sgtty.
|
||||||
|
|
||||||
|
|
||||||
|
# Revision history
|
||||||
|
# $Log$
|
||||||
|
# Revision 2.1 2005-06-24 23:20:41 dtrg
|
||||||
|
# Added some new readmes at the top level.
|
||||||
|
#
|
||||||
146
TakeAction
Executable file
146
TakeAction
Executable file
@ -0,0 +1,146 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
case $# in
|
||||||
|
0) PAR='make install && make clean' ; CMD=Action ;;
|
||||||
|
1) PAR="$1" ; CMD=Action ;;
|
||||||
|
2) PAR="$1" ; CMD="$2" ;;
|
||||||
|
*) echo Syntax: "$0" [command [file]] ; exit 1 ;;
|
||||||
|
esac
|
||||||
|
if test -r "$CMD"
|
||||||
|
then :
|
||||||
|
else
|
||||||
|
case "$CMD" in
|
||||||
|
Action) echo No Action file present ;;
|
||||||
|
*) echo No Action file "($CMD)" present ;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
case $0 in
|
||||||
|
/*) THISFILE=$0
|
||||||
|
;;
|
||||||
|
*) if [ -f $0 ]
|
||||||
|
then
|
||||||
|
THISFILE=`pwd`/$0
|
||||||
|
else
|
||||||
|
THISFILE=$0
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
SYS=
|
||||||
|
RETC=0
|
||||||
|
{ while read LINE
|
||||||
|
do
|
||||||
|
eval set $LINE
|
||||||
|
case x"$1" in
|
||||||
|
x!*) ;;
|
||||||
|
xname) SYS="$2"
|
||||||
|
ACTION='$PAR'
|
||||||
|
DIR=.
|
||||||
|
FM=no
|
||||||
|
FAIL='Failed for $SYS, see $DIR/Out'
|
||||||
|
SUCC='$SYS -- done'
|
||||||
|
ATYPE=
|
||||||
|
FATAL=no
|
||||||
|
DOIT=yes
|
||||||
|
;;
|
||||||
|
xfatal) FATAL=yes ;;
|
||||||
|
xaction|xindir) case x$ATYPE in
|
||||||
|
x) ACTION=$2 ; ATYPE=$1
|
||||||
|
case $ATYPE$FM in
|
||||||
|
indirno) FAIL='Failed for $SYS' ;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
*) echo Already specified an $ATYPE for this name
|
||||||
|
RETC=65 ;;
|
||||||
|
esac ;;
|
||||||
|
xfailure) FM=yes
|
||||||
|
FAIL="$2" ;;
|
||||||
|
xsuccess) SUCC="$2" ;;
|
||||||
|
xdir) DIR="$2" ;;
|
||||||
|
xsystem) PAT="$2"
|
||||||
|
oIFS=$IFS
|
||||||
|
IFS="|"
|
||||||
|
eval set $2
|
||||||
|
case x`ack_sys` in
|
||||||
|
x$1|x$2|x$3|x$4|x$5|x$6|x$7) ;;
|
||||||
|
*) echo "Sorry, $SYS can only be made on $PAT systems"
|
||||||
|
DOIT=no
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
IFS=$oIFS
|
||||||
|
;;
|
||||||
|
xend) case $DOIT in
|
||||||
|
no) continue ;;
|
||||||
|
esac
|
||||||
|
case x$SYS in
|
||||||
|
x) echo Missing name line; RETC=65 ;;
|
||||||
|
*) if test -d $DIR
|
||||||
|
then (
|
||||||
|
cd $DIR
|
||||||
|
X=
|
||||||
|
case $ATYPE in
|
||||||
|
indir)
|
||||||
|
if $THISFILE "$PAR" $ACTION
|
||||||
|
then eval echo $SUCC
|
||||||
|
else RETC=2 ; eval echo $FAIL
|
||||||
|
fi ;;
|
||||||
|
*)
|
||||||
|
case "$ACTION" in
|
||||||
|
'$PAR')
|
||||||
|
ACTION="$PAR"
|
||||||
|
;;
|
||||||
|
*) ;;
|
||||||
|
esac
|
||||||
|
if [ -f No$CMD ]
|
||||||
|
then
|
||||||
|
x=`cat No$CMD`
|
||||||
|
if [ "$ACTION" = "$x" ]
|
||||||
|
then
|
||||||
|
ACTION='echo "No actions performed, No$CMD file present"'
|
||||||
|
SUCC='$SYS -- skipped'
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if eval "{ $ACTION ; } >Out 2>&1 </dev/null"
|
||||||
|
then eval echo $SUCC
|
||||||
|
if [ "$SUCC" = '$SYS -- skipped' ]
|
||||||
|
then :
|
||||||
|
else echo "$ACTION" > No$CMD 2>/dev/null
|
||||||
|
fi
|
||||||
|
else RETC=1 ; X=: ; eval echo $FAIL
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
(echo ------- `pwd`
|
||||||
|
cat Out
|
||||||
|
$X rm -f Out
|
||||||
|
) 2>/dev/null 1>&- 1>&3
|
||||||
|
exit $RETC
|
||||||
|
)
|
||||||
|
case $? in
|
||||||
|
0) ;;
|
||||||
|
*) case $RETC in
|
||||||
|
0) RETC=$? ;;
|
||||||
|
esac ;;
|
||||||
|
esac
|
||||||
|
else
|
||||||
|
echo Directory $DIR for $SYS is inaccessible
|
||||||
|
RETC=66
|
||||||
|
fi ;;
|
||||||
|
esac
|
||||||
|
case $FATAL$RETC in
|
||||||
|
yes0) ;;
|
||||||
|
yes*) echo Fatal error, installation stopped.
|
||||||
|
exit $RETC ;;
|
||||||
|
esac
|
||||||
|
SYS=
|
||||||
|
;;
|
||||||
|
*) echo Unknown keyword "$1"
|
||||||
|
RETC=67 ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
exit $RETC
|
||||||
|
} <$CMD
|
||||||
|
RETX=$?
|
||||||
|
case $RETX in
|
||||||
|
0) exit $RETC ;;
|
||||||
|
*) exit $RETX ;;
|
||||||
|
esac
|
||||||
9
bin/.distr
Normal file
9
bin/.distr
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
cc-and-mkdep.ack
|
||||||
|
cc-and-mkdep.all
|
||||||
|
cc-and-mkdep.sun
|
||||||
|
do_deps
|
||||||
|
do_resolve
|
||||||
|
lint-lib.ack
|
||||||
|
lint-lib.unix
|
||||||
|
mk_manpage
|
||||||
|
rm_deps
|
||||||
8
bin/cc-and-mkdep.ack
Executable file
8
bin/cc-and-mkdep.ack
Executable file
@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
: '$Id$'
|
||||||
|
|
||||||
|
: Compile and make dependencies. First argument is the file on which the
|
||||||
|
: dependencies must be produced. This version is for ACK.
|
||||||
|
n=$1
|
||||||
|
shift
|
||||||
|
exec $CC -Rcem-A$n -Rcem-m $*
|
||||||
21
bin/cc-and-mkdep.all
Executable file
21
bin/cc-and-mkdep.all
Executable file
@ -0,0 +1,21 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
: '$Id$'
|
||||||
|
|
||||||
|
: Compile and make dependencies. First argument is the file on which the
|
||||||
|
: dependencies must be produced. This version is a generic one that should
|
||||||
|
: work for all Unix systems.
|
||||||
|
n=$1
|
||||||
|
shift
|
||||||
|
cpp_args=
|
||||||
|
for i in $*
|
||||||
|
do
|
||||||
|
case $i in
|
||||||
|
-I*|-D*|-U*) cpp_args="$cpp_args $i"
|
||||||
|
;;
|
||||||
|
-*) ;;
|
||||||
|
*) cpp_args="$cpp_args $i"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
$UTIL_HOME/lib.bin/cpp -d -m $cpp_args > $n 2>/dev/null
|
||||||
|
exec $CC $*
|
||||||
8
bin/cc-and-mkdep.sun
Executable file
8
bin/cc-and-mkdep.sun
Executable file
@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
: '$Id$'
|
||||||
|
|
||||||
|
: Compile and make dependencies. First argument is the file on which the
|
||||||
|
: dependencies must be produced. This version is for the SUN cc.
|
||||||
|
n=$1
|
||||||
|
shift
|
||||||
|
exec $CC -Qpath $UTIL_HOME/lib.bin -Qoption cpp -d$n -Qoption cpp -m $*
|
||||||
19
bin/do_deps
Executable file
19
bin/do_deps
Executable file
@ -0,0 +1,19 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
: '$Id$'
|
||||||
|
|
||||||
|
: Produce dependencies for all argument files
|
||||||
|
|
||||||
|
for i in $*
|
||||||
|
do
|
||||||
|
n=`basename $i .c`
|
||||||
|
if [ -f $n.dep ]
|
||||||
|
then
|
||||||
|
:
|
||||||
|
else
|
||||||
|
echo $n.'$(SUF): '$i > $n.dep
|
||||||
|
echo " head -5 $n.dep > $n.dp1" >> $n.dep
|
||||||
|
echo ' CC="$(CC)" UTIL_HOME="$(UTIL_HOME)" $(CC_AND_MKDEP) '$n.dp2 '$(CFLAGS)' -c $i >> $n.dep
|
||||||
|
echo " cat $n.dp1 $n.dp2 > $n.dep" >> $n.dep
|
||||||
|
echo " rm -f $n.dp1 $n.dp2" >> $n.dep
|
||||||
|
fi
|
||||||
|
done
|
||||||
48
bin/do_resolve
Executable file
48
bin/do_resolve
Executable file
@ -0,0 +1,48 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
: '$Id$'
|
||||||
|
|
||||||
|
: Resolve name clashes in the files on the argument list. If these
|
||||||
|
: files reside in another directory, a copy is made in the current
|
||||||
|
: directory. If not, it is overwritten. Never do this in a source
|
||||||
|
: directory! A list of the new files is produced on standard output.
|
||||||
|
|
||||||
|
UTIL_BIN=$UTIL_HOME/bin
|
||||||
|
|
||||||
|
trap "rm -f tmp$$ a.out nmclash.* longnames clashes" 0 1 2 3 15
|
||||||
|
|
||||||
|
: first find out if we have to resolve problems with identifier significance.
|
||||||
|
|
||||||
|
cat > nmclash.c <<'EOF'
|
||||||
|
/* Accepted if many characters of long names are significant */
|
||||||
|
abcdefghijklmnopr() { }
|
||||||
|
abcdefghijklmnopq() { }
|
||||||
|
main() { }
|
||||||
|
EOF
|
||||||
|
if $CC nmclash.c
|
||||||
|
then : no identifier significance problem
|
||||||
|
for i in $*
|
||||||
|
do
|
||||||
|
echo $i
|
||||||
|
done
|
||||||
|
else
|
||||||
|
$UTIL_BIN/prid -l7 $* > longnames
|
||||||
|
|
||||||
|
: remove code generating routines from the clashes list.
|
||||||
|
: code generating routine names start with C_.
|
||||||
|
: also remove names starting with flt_.
|
||||||
|
|
||||||
|
sed '/^C_/d' < longnames | sed '/^flt_/d' > tmp$$
|
||||||
|
$UTIL_BIN/cclash -c -l7 tmp$$ > clashes
|
||||||
|
for i in $*
|
||||||
|
do
|
||||||
|
$UTIL_BIN/cid -Fclashes < $i > tmp$$
|
||||||
|
n=`basename $i .xxx`
|
||||||
|
if cmp -s $n tmp$$
|
||||||
|
then
|
||||||
|
rm -f tmp$$
|
||||||
|
else
|
||||||
|
mv tmp$$ $n
|
||||||
|
fi
|
||||||
|
echo $n
|
||||||
|
done
|
||||||
|
fi
|
||||||
13
bin/lint-lib.ack
Executable file
13
bin/lint-lib.ack
Executable file
@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
: '$Id$'
|
||||||
|
|
||||||
|
: Create a lint library file. The name of the library file is constructed
|
||||||
|
: from the first argument. The second argument indicates the directory where
|
||||||
|
: the result is to be placed. This version is for ACK lint.
|
||||||
|
|
||||||
|
n=$1
|
||||||
|
shift
|
||||||
|
d=$1
|
||||||
|
shift
|
||||||
|
lint -L$n $*
|
||||||
|
mv $n.llb $d
|
||||||
13
bin/lint-lib.unix
Executable file
13
bin/lint-lib.unix
Executable file
@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
: '$Id$'
|
||||||
|
|
||||||
|
: Create a lint library file. The name of the library file is constructed
|
||||||
|
: from the first argument. The second argument indicates the directory where
|
||||||
|
: the result is to be placed. This version is for Unix lint.
|
||||||
|
|
||||||
|
n=$1
|
||||||
|
shift
|
||||||
|
d=$1
|
||||||
|
shift
|
||||||
|
/usr/bin/lint -C$n $*
|
||||||
|
mv llib-l$n.ln $d
|
||||||
20
bin/mk_manpage
Executable file
20
bin/mk_manpage
Executable file
@ -0,0 +1,20 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
num=`expr $1 : '.*\.\([1-8]\)'`
|
||||||
|
|
||||||
|
if [ -d $2/man ] ; then : ; else mkdir $2/man ; fi
|
||||||
|
if [ -f $2/man/head ] ; then : ; else cat > $2/man/head <<'EOF'
|
||||||
|
.rn TH yy
|
||||||
|
.de TH
|
||||||
|
.di zz
|
||||||
|
.yy "\\$1" "\\$2" "\\$3" "\\$4"
|
||||||
|
.ds ]W 5th ACK distribution
|
||||||
|
.ds ]D Amsterdam Compiler Kit
|
||||||
|
.ds ]L "\\$3
|
||||||
|
.di
|
||||||
|
.rm zz
|
||||||
|
..
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
if [ -d $2/man/man$num ] ; then : ; else mkdir $2/man/man$num ; fi
|
||||||
|
cat $2/man/head $1 | sed "s!TARGETHOME!$2!" > $2/man/man$num/`expr //$1 : '.*/\([^/]*\)'`
|
||||||
9
bin/rm_deps
Executable file
9
bin/rm_deps
Executable file
@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
: $Id$
|
||||||
|
|
||||||
|
: remove dependencies from a makefile, write result on standard output.
|
||||||
|
: we cannot do this directly in a makefile because some make versions
|
||||||
|
: have # start a comment, always.
|
||||||
|
|
||||||
|
sed -e '/^#DEPENDENCIES/,$d' $1
|
||||||
|
echo '#DEPENDENCIES'
|
||||||
71
config.pm
Normal file
71
config.pm
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
-- ======================================================================= --
|
||||||
|
-- ACK CONFIGURATION --
|
||||||
|
-- (Edit this before building) --
|
||||||
|
-- ======================================================================= --
|
||||||
|
|
||||||
|
-- What platform to build for by default?
|
||||||
|
|
||||||
|
DEFAULT_PLATFORM = "pc86"
|
||||||
|
|
||||||
|
-- Where should the ACK put its temporary files?
|
||||||
|
|
||||||
|
ACK_TEMP_DIR = "/tmp"
|
||||||
|
|
||||||
|
-- Where is the ACK going to be installed, eventually?
|
||||||
|
|
||||||
|
PREFIX = "/usr/local"
|
||||||
|
|
||||||
|
-- ======================================================================= --
|
||||||
|
-- BROKEN ACK CONFIGURATION --
|
||||||
|
-- (Currently not editable) --
|
||||||
|
-- ======================================================================= --
|
||||||
|
|
||||||
|
-- FIXME: the following two variables must be set to their Minix variants
|
||||||
|
-- due to hard-coded references in the descr files.
|
||||||
|
|
||||||
|
-- Name of the platform-independent library directory; 'share' on modern
|
||||||
|
-- systems, 'lib' on Minix-like systems.
|
||||||
|
|
||||||
|
PLATIND = "lib"
|
||||||
|
|
||||||
|
-- Name of the platform-dependent library directory; 'lib' on modern
|
||||||
|
-- systems, 'lib.bin' on Minix-like systems.
|
||||||
|
|
||||||
|
PLATDEP = "lib.bin"
|
||||||
|
|
||||||
|
-- ======================================================================= --
|
||||||
|
-- BUILD SYSTEM CONFIGURATION --
|
||||||
|
-- (Not user servicable) --
|
||||||
|
-- ======================================================================= --
|
||||||
|
|
||||||
|
-- Absolute path to the ACK source directory.
|
||||||
|
|
||||||
|
ROOTDIR = posix.getcwd().."/"
|
||||||
|
|
||||||
|
-- Temporary directory used during the build process.
|
||||||
|
|
||||||
|
TEMPDIR = "/tmp/ack-temp/"
|
||||||
|
|
||||||
|
-- Directory in which dynamically generated header files will go during
|
||||||
|
-- the build process.
|
||||||
|
|
||||||
|
HEADERDIR = TEMPDIR.."headers/"
|
||||||
|
|
||||||
|
-- Directory in which tools used by the build process but which not actually
|
||||||
|
-- deployed with the ACK will go.
|
||||||
|
|
||||||
|
TOOLDIR = TEMPDIR.."tools/"
|
||||||
|
|
||||||
|
-- Directory in which the libraries used to build the ACK tools but which are
|
||||||
|
-- not actually deployed with the ACK will go.
|
||||||
|
|
||||||
|
LIBDIR = TEMPDIR.."lib/"
|
||||||
|
|
||||||
|
-- Staging area where the installation will be built before actually copying
|
||||||
|
-- it.
|
||||||
|
|
||||||
|
BINDIR = TEMPDIR.."staging/"
|
||||||
|
|
||||||
|
-- Directory that the pm cache goes in.
|
||||||
|
|
||||||
|
pm.intermediate_cache_dir = TEMPDIR.."pmcache/"
|
||||||
15
distr/Exceptions
Normal file
15
distr/Exceptions
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
++ ./doc/install.pr made
|
||||||
|
++ ./doc/int/.distr made
|
||||||
|
++ ./etc/new_table_done made
|
||||||
|
++ ./lang/cem/cemcom.ansi/Version.c made
|
||||||
|
++ ./lang/cem/libcc.ansi/stdlib/malloc.c made
|
||||||
|
++ ./lang/cem/cemcom/Version.c made
|
||||||
|
++ ./lang/pc/comp/Version.c made
|
||||||
|
++ ./lang/m2/comp/Version.c made
|
||||||
|
++ ./lang/m2/m2mm/Version.c made
|
||||||
|
++ ./mach/sparc/ce/EM_table made
|
||||||
|
++ ./mach/sparc_solaris/libem/LIST made
|
||||||
|
++ ./util/LLgen/src/LLgen.c.dist made
|
||||||
|
++ ./util/cpp/Version.c made
|
||||||
|
++ ./util/ego/share/pop_push.h made
|
||||||
|
++ ./util/grind/ops.c made
|
||||||
90
distr/How_To
Normal file
90
distr/How_To
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
How to make a distribution
|
||||||
|
--------------------------
|
||||||
|
|
||||||
|
I have written a new tool to generate the distributions that does not rely on
|
||||||
|
having a local CVS server --- distr/mkdist.
|
||||||
|
|
||||||
|
To use it, you need to specify your CVS work tree, the destination directory
|
||||||
|
that the distribution will be written to, plus flags. It should be self-
|
||||||
|
documenting; use:
|
||||||
|
|
||||||
|
mkdist --help
|
||||||
|
|
||||||
|
...to get documentation.
|
||||||
|
|
||||||
|
It uses .distr files in exactly the same way as the previous mechanism.
|
||||||
|
|
||||||
|
The documentation for the old distribution tools follows.
|
||||||
|
|
||||||
|
David Given
|
||||||
|
dg@cowlark.com
|
||||||
|
2005-06-25
|
||||||
|
|
||||||
|
-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
How to make a fresh distribution:
|
||||||
|
For a distribution you need ".distr" files and RCS files.
|
||||||
|
The EM home directory contains a file called ".distr". It contains
|
||||||
|
the names of all the files and directories you want to have in the distribution.
|
||||||
|
The directories should contain .distr files, the other files should
|
||||||
|
be placed under CVS.
|
||||||
|
There are files that derive from other files and yet should be placed
|
||||||
|
in the distribution.
|
||||||
|
These files should not be placed under RCS or CVS.
|
||||||
|
The file "Exceptions" in this directory contains the current list of
|
||||||
|
these files.
|
||||||
|
|
||||||
|
When all this is correct, use the shell script mktree the extract
|
||||||
|
the distribution from the EM tree.
|
||||||
|
sh mktree destination_tree repository_tree <distrname> 2>f.attf
|
||||||
|
Use the "cvs rtag" command to give the distribution a name first!
|
||||||
|
Make sure that the destination tree exists and is empty!
|
||||||
|
Failing to do that will almost certainly result in a welter of
|
||||||
|
error messages.
|
||||||
|
The file f.attf contains mktree error messages and should be compared
|
||||||
|
to Exceptions.
|
||||||
|
The actions of mktree are quite complicated. It starts in the current
|
||||||
|
directory creating a version in the destination directory.
|
||||||
|
Then it reads the .distr file.
|
||||||
|
For each file mentioned there it performes certain actions:
|
||||||
|
1- Directory Change to that directory and call yourself recursively.
|
||||||
|
2- File
|
||||||
|
a- Does a file LIST exist in this directory AND
|
||||||
|
is the first line of LIST equal to the name of the
|
||||||
|
destination file? If so, try to extract all the files
|
||||||
|
named in the rest of the LIST file and call the program
|
||||||
|
arch to create a library "arch cDr `cat LIST`".
|
||||||
|
In this manner libraries can be distributed whose members
|
||||||
|
have their own RCS file.
|
||||||
|
else
|
||||||
|
b- Try to run 'make distr'
|
||||||
|
else
|
||||||
|
c- Try to run 'make <filename>'
|
||||||
|
else
|
||||||
|
d- give message that says "not present" (or some such).
|
||||||
|
|
||||||
|
Now, the tree contains all the files in the distribution, but it also contains
|
||||||
|
files that should not be in the distribution, especially the files created
|
||||||
|
by CVS.
|
||||||
|
That is why we now give the command:
|
||||||
|
dtar cdf distr .
|
||||||
|
The file distr is the one you should put on tape!
|
||||||
|
But,.... before doing that: Try it out!
|
||||||
|
Repeat the process described in the installation manual.
|
||||||
|
Only if that succeeds you are sure that you included the files needed.
|
||||||
|
Good Luck,
|
||||||
|
Ed Keizer, 85/4/15.
|
||||||
|
|
||||||
|
Updated for 3rd distribution by Ceriel Jacobs, 87/3/11.
|
||||||
|
And again,
|
||||||
|
Good Luck!
|
||||||
|
|
||||||
|
Updated for 4th distribution by Ceriel Jacobs, 88/4/08.
|
||||||
|
And again,
|
||||||
|
Good Luck!
|
||||||
|
Updated for 5th distribution by Ceriel Jacobs, 91/19/12.
|
||||||
|
And again,
|
||||||
|
Good Luck!
|
||||||
|
Updated for 1st upgrade to 5th distribution by Ceriel Jacobs, 91/12/11.
|
||||||
|
And again,
|
||||||
|
Good Luck!
|
||||||
26
distr/dwalk
Executable file
26
distr/dwalk
Executable file
@ -0,0 +1,26 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
: ${CDIR=.}
|
||||||
|
${DF-:} $CDIR .distr
|
||||||
|
if test ! -r $DESTDIR/$CDIR/.distr
|
||||||
|
then
|
||||||
|
echo ++ no .distr in $CDIR 1>&2
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
for i in `cat $DESTDIR/$CDIR/.distr`
|
||||||
|
do
|
||||||
|
if test -d $i
|
||||||
|
then
|
||||||
|
( if cd $i
|
||||||
|
then
|
||||||
|
CDIR=$CDIR/$i
|
||||||
|
export CDIR
|
||||||
|
exec $DDIR/dwalk $*
|
||||||
|
else
|
||||||
|
echo ++ Could not access $CDIR/$i 1>&2
|
||||||
|
fi
|
||||||
|
)
|
||||||
|
else
|
||||||
|
${DF-:} $CDIR $i
|
||||||
|
fi
|
||||||
|
done
|
||||||
1
distr/echod
Executable file
1
distr/echod
Executable file
@ -0,0 +1 @@
|
|||||||
|
echo $1
|
||||||
10
distr/listall
Executable file
10
distr/listall
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
case $# in
|
||||||
|
0) DESTDIR=. ;;
|
||||||
|
1) DESTDIR=$1 ;;
|
||||||
|
*) echo $0 [directory] ; exit 1 ;;
|
||||||
|
esac
|
||||||
|
DD=`pwd`/listall.d
|
||||||
|
DW=`pwd`/dwalk
|
||||||
|
export DD DESTDIR
|
||||||
|
cd $DESTDIR
|
||||||
|
$DW
|
||||||
2
distr/listall.d
Executable file
2
distr/listall.d
Executable file
@ -0,0 +1,2 @@
|
|||||||
|
echo "<$1>"
|
||||||
|
ls -bCdx `cat .distr`
|
||||||
10
distr/listdirs
Executable file
10
distr/listdirs
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
case $# in
|
||||||
|
0) DIR=. ;;
|
||||||
|
1) DIR=$1 ;;
|
||||||
|
*) echo $0 [directory] ; exit 1 ;;
|
||||||
|
esac
|
||||||
|
DD=`pwd`/echod
|
||||||
|
DW=`pwd`/dwalk
|
||||||
|
export DD
|
||||||
|
cd $DIR
|
||||||
|
$DW
|
||||||
40
distr/mk_distr_syms
Executable file
40
distr/mk_distr_syms
Executable file
@ -0,0 +1,40 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
: Utility to make a tree of symbolic links to source tree.
|
||||||
|
: Mount the source tree read-only, use this script, and then try installation.
|
||||||
|
case $# in
|
||||||
|
2) ;;
|
||||||
|
*) echo "Usage: $0 <source-tree> <symlink-tree>" 1>&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
if [ -f $1/.distr ]
|
||||||
|
then
|
||||||
|
for i in `cat $1/.distr`
|
||||||
|
do
|
||||||
|
if [ -d $1/$i ]
|
||||||
|
then
|
||||||
|
if mkdir $2/$i && $0 $1/$i $2/$i
|
||||||
|
then
|
||||||
|
:
|
||||||
|
else
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
if [ -f $1/$i ]
|
||||||
|
then
|
||||||
|
if ln -s $1/$i $2/$i
|
||||||
|
then
|
||||||
|
:
|
||||||
|
else
|
||||||
|
exit 3
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Missing file $1/$i" 1>&2
|
||||||
|
exit 4
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
else
|
||||||
|
echo "No .distr file in $1" 1>&2
|
||||||
|
exit 5
|
||||||
|
fi
|
||||||
11
distr/mka
Executable file
11
distr/mka
Executable file
@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -e
|
||||||
|
for i in `tail +2 $DESTDIR/$1/LIST`
|
||||||
|
do
|
||||||
|
${DF-false} $1 $i
|
||||||
|
done
|
||||||
|
cd $DESTDIR/$1
|
||||||
|
arch cDr `cat LIST`
|
||||||
|
: I do not remove the files constituating the library, because
|
||||||
|
: they might be present in .distr
|
||||||
177
distr/mkdist
Executable file
177
distr/mkdist
Executable file
@ -0,0 +1,177 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# $Source$
|
||||||
|
# $State$
|
||||||
|
|
||||||
|
# Set up default variables.
|
||||||
|
|
||||||
|
destdir=
|
||||||
|
srcdir=`pwd`
|
||||||
|
arch=/usr/local/bin/arch
|
||||||
|
delete=no
|
||||||
|
copy="ln"
|
||||||
|
|
||||||
|
# --- Options parsing -------------------------------------------------------
|
||||||
|
|
||||||
|
while [ "$1" != "" ]; do
|
||||||
|
case "$1" in
|
||||||
|
-s|--srcdir)
|
||||||
|
srcdir="$2"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
-d|--destdir)
|
||||||
|
destdir="$2"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
-x|--delete)
|
||||||
|
delete=yes
|
||||||
|
;;
|
||||||
|
|
||||||
|
-c|--copy)
|
||||||
|
copy="cp -Rp"
|
||||||
|
;;
|
||||||
|
|
||||||
|
-S|--symlink)
|
||||||
|
copy="ln -s"
|
||||||
|
;;
|
||||||
|
|
||||||
|
-a|--arch)
|
||||||
|
arch="$2"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
-h|--help)
|
||||||
|
echo "mkdist [options]"
|
||||||
|
echo "Options are:"
|
||||||
|
echo " -s --srcdir <path> The CVS tree to read from. (default: CWD)"
|
||||||
|
echo " -d --destdir <path> The directory to create the distribution in."
|
||||||
|
echo " -x --delete Erase the destination directory first."
|
||||||
|
echo " -c --copy Make physical copies of the files. (default: hardlink)"
|
||||||
|
echo " -S --symlink Make symbolic links instead of copying or hardlinking."
|
||||||
|
echo " -a --arch <path> Where the ACK 'arch' tool is."
|
||||||
|
echo " -h --help Display this message."
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
echo "Unrecognised option. Try --help for help."
|
||||||
|
exit 1
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ "$destdir" = "" ]; then
|
||||||
|
echo "You must specify a destination directory. (Try --help for help.)"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# --- Main routines ---------------------------------------------------------
|
||||||
|
|
||||||
|
# These two routines do the work of traversing the source tree and building
|
||||||
|
# the distribution tree.
|
||||||
|
|
||||||
|
addfile() {
|
||||||
|
local f
|
||||||
|
f="${1##$srcdir/}"
|
||||||
|
mkdir -p $destdir/`dirname $f`
|
||||||
|
$copy "$1" "$destdir/$f"
|
||||||
|
}
|
||||||
|
|
||||||
|
process_dir() {
|
||||||
|
local path
|
||||||
|
local archivename
|
||||||
|
|
||||||
|
path=$1
|
||||||
|
cd $path
|
||||||
|
echo $PWD
|
||||||
|
|
||||||
|
# Look for a LIST file and cache the first line.
|
||||||
|
|
||||||
|
archivename=
|
||||||
|
if [ -f LIST ]; then
|
||||||
|
archivename=`head -1 LIST`
|
||||||
|
fi
|
||||||
|
|
||||||
|
for i in `cat $path/.distr`; do
|
||||||
|
case "$i" in
|
||||||
|
\#*) # Comment. Do nothing.
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
if [ -d $i ]; then
|
||||||
|
# This is a directory. Recurse into it.
|
||||||
|
|
||||||
|
( process_dir $path/$i )
|
||||||
|
elif [ -f $i ]; then
|
||||||
|
# This is a file.
|
||||||
|
|
||||||
|
addfile $path/$i
|
||||||
|
elif [ "$i" = "$archivename" ]; then
|
||||||
|
# Build the named archive.
|
||||||
|
|
||||||
|
$arch cDr `cat LIST`
|
||||||
|
addfile $path/$archivename
|
||||||
|
else
|
||||||
|
echo "Don't know what to do with $i, listed in $PWD/.distr."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
# --- Main program ----------------------------------------------------------
|
||||||
|
|
||||||
|
# Test to make sure that $arch points to the right thing.
|
||||||
|
|
||||||
|
if !(strings $arch | grep archiver > /dev/null); then
|
||||||
|
echo "$arch does not seem to point at the ACK archiver tool."
|
||||||
|
echo "(Don't confuse this with the Linux tool for displaying your"
|
||||||
|
echo "architecture.)"
|
||||||
|
echo ""
|
||||||
|
echo "Press RETURN to go ahead anyway, or CTRL+C to abort."
|
||||||
|
read ignored
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Actually do the work.
|
||||||
|
|
||||||
|
echo "Creating distribution from CVS tree: $srcdir"
|
||||||
|
echo " into destination tree: $destdir"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
if [ -e $destdir ]; then
|
||||||
|
if [ "$delete" = "yes" ]; then
|
||||||
|
echo "Press RETURN to erase $destdir and its contents, or CTRL+C to abort."
|
||||||
|
read
|
||||||
|
echo "Erasing..."
|
||||||
|
rm -rf "$destdir"
|
||||||
|
else
|
||||||
|
echo "$destdir exists. Aborting."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Working..."
|
||||||
|
mkdir -p $destdir
|
||||||
|
process_dir $srcdir
|
||||||
|
echo "Done."
|
||||||
|
|
||||||
|
# Revision history
|
||||||
|
# $Log$
|
||||||
|
# Revision 1.5 2007-04-24 19:48:41 dtrg
|
||||||
|
# Removed bashish.
|
||||||
|
#
|
||||||
|
# Revision 1.4 2007/02/25 20:56:41 dtrg
|
||||||
|
# Performed major renovations to make the script work on OpenBSD.
|
||||||
|
#
|
||||||
|
# Revision 1.3 2007/02/24 02:05:56 dtrg
|
||||||
|
# Removed some bashish; added comment support; removed the make
|
||||||
|
# distr functionality, as nothing was using it any more and it was
|
||||||
|
# causing problems.
|
||||||
|
#
|
||||||
|
# Revision 1.2 2005/06/24 23:19:23 dtrg
|
||||||
|
# Added new mkdist tool.
|
||||||
|
#
|
||||||
|
# Revision 1.1 2005/06/24 22:13:57 dtrg
|
||||||
|
# Created new tool to generate distributions.
|
||||||
19
distr/mkf
Executable file
19
distr/mkf
Executable file
@ -0,0 +1,19 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
if [ -f $DESTDIR/$1/$2 ]
|
||||||
|
then
|
||||||
|
:
|
||||||
|
elif grep LIST $DESTDIR/$1/.distr >/dev/null 2>&1 &&
|
||||||
|
(test "$2" = "`head -1 $DESTDIR/$1/LIST`") >/dev/null 2>&1 &&
|
||||||
|
${DA-false} "$1" "$2"
|
||||||
|
then
|
||||||
|
: Fetched library contents one by one and put them together
|
||||||
|
elif ( cd $DESTDIR/$1 ; make distr ) > /dev/null 2>&1
|
||||||
|
then
|
||||||
|
echo ++ $1/$2 made 1>&2
|
||||||
|
elif ( cd $DESTDIR/$1 ; make $2 ) > /dev/null 2>&1
|
||||||
|
then
|
||||||
|
echo ++ $1/$2 made 1>&2
|
||||||
|
else
|
||||||
|
echo ++ $1/$2 not present 1>&2
|
||||||
|
fi
|
||||||
42
distr/mktree
Normal file
42
distr/mktree
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
case $# in
|
||||||
|
2|3) ;;
|
||||||
|
*) echo Usage: $0 directory repdir [ SVrecord ] 1>&2 ; exit 1 ;;
|
||||||
|
esac
|
||||||
|
case $0 in
|
||||||
|
/*) DDIR=`dirname $0`
|
||||||
|
;;
|
||||||
|
*) DDIR=`pwd`/`dirname $0`
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
case $1 in
|
||||||
|
/*) DESTDIR=$1 ;;
|
||||||
|
*) DESTDIR=`pwd`/$1 ;;
|
||||||
|
esac
|
||||||
|
case $2 in
|
||||||
|
/*) REPDIR=$2 ;;
|
||||||
|
*) REPDIR=`pwd`/$2 ;;
|
||||||
|
esac
|
||||||
|
# DD=$DDIR/mkd
|
||||||
|
# export DD
|
||||||
|
mkdir -p $DESTDIR
|
||||||
|
CVSROOT=/usr/proj/em/Repositories
|
||||||
|
export CVSROOT
|
||||||
|
cd $DESTDIR
|
||||||
|
case $# in
|
||||||
|
3)
|
||||||
|
cvs checkout world -r $3
|
||||||
|
;;
|
||||||
|
2)
|
||||||
|
cvs checkout world
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
cd $REPDIR
|
||||||
|
DF=$DDIR/mkf
|
||||||
|
DA=$DDIR/mka
|
||||||
|
export DDIR DESTDIR DF DA REPDIR
|
||||||
|
|
||||||
|
$DDIR/dwalk
|
||||||
|
|
||||||
|
cd $DESTDIR
|
||||||
|
find . -type d -print | xargs chmod "uog+rx"
|
||||||
|
chmod -R "og-w,u+w,uog+r" .
|
||||||
26
distr/todistr
Normal file
26
distr/todistr
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
REV=
|
||||||
|
FILE=
|
||||||
|
while :
|
||||||
|
do
|
||||||
|
case $# in
|
||||||
|
0) break ;;
|
||||||
|
esac
|
||||||
|
ARG="$1"
|
||||||
|
shift
|
||||||
|
case "$ARG" in
|
||||||
|
-r*) REV=`echo "$ARG"| sed s/-r//` ;;
|
||||||
|
-*) FLAGS="$FLAGS $ARG" ;;
|
||||||
|
*) case x$FILE in
|
||||||
|
x) FILE="$ARG" ;;
|
||||||
|
*) echo todistr can only be done on one file at the time
|
||||||
|
exit 1 ;;
|
||||||
|
esac
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
case x$REV in
|
||||||
|
x) REV=`rlog -h "$FILE"|sed -n -e '/head/s/^head:[ ]*//p'` ;;
|
||||||
|
esac
|
||||||
|
case x$REV in
|
||||||
|
x) exit 2 ;;
|
||||||
|
esac
|
||||||
|
rcs -ndistr4:$REV $FLAGS $FILE
|
||||||
32
doc/.distr
Normal file
32
doc/.distr
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
READ_ME
|
||||||
|
Makefile
|
||||||
|
proto.make
|
||||||
|
ack.doc
|
||||||
|
basic.doc
|
||||||
|
cg.doc
|
||||||
|
crefman.doc
|
||||||
|
ansi_C.doc
|
||||||
|
em
|
||||||
|
install.doc
|
||||||
|
install.pr
|
||||||
|
ncg.doc
|
||||||
|
pcref.doc
|
||||||
|
peep.doc
|
||||||
|
regadd.doc
|
||||||
|
toolkit.doc
|
||||||
|
v7bugs.doc
|
||||||
|
val.doc
|
||||||
|
6500.doc
|
||||||
|
i80.doc
|
||||||
|
z80.doc
|
||||||
|
m68020.doc
|
||||||
|
m2ref.doc
|
||||||
|
nopt.doc
|
||||||
|
top
|
||||||
|
ego
|
||||||
|
occam
|
||||||
|
int
|
||||||
|
ceg
|
||||||
|
sparc
|
||||||
|
lint
|
||||||
|
pascal
|
||||||
1893
doc/6500.doc
Normal file
1893
doc/6500.doc
Normal file
File diff suppressed because it is too large
Load Diff
4
doc/LLgen/.distr
Normal file
4
doc/LLgen/.distr
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
LLgen.n
|
||||||
|
LLgen_NCER.n
|
||||||
|
LLgen.refs
|
||||||
|
proto.make
|
||||||
1077
doc/LLgen/LLgen.n
Normal file
1077
doc/LLgen/LLgen.n
Normal file
File diff suppressed because it is too large
Load Diff
54
doc/LLgen/LLgen.refs
Normal file
54
doc/LLgen/LLgen.refs
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
%T An ALL(1) Compiler Generator
|
||||||
|
%A D. R. Milton
|
||||||
|
%A L. W. Kirchhoff
|
||||||
|
%A B. R. Rowland
|
||||||
|
%B Proc. of the SIGPLAN '79 Symposium on Compiler Construction
|
||||||
|
%D August 1979
|
||||||
|
%J SIGPLAN Notices
|
||||||
|
%N 8
|
||||||
|
%P 152-157
|
||||||
|
%V 14
|
||||||
|
|
||||||
|
%T Lex - A Lexical Analyser Generator
|
||||||
|
%A M. E. Lesk
|
||||||
|
%I Bell Laboratories
|
||||||
|
%D October 1975
|
||||||
|
%C Murray Hill, New Jersey
|
||||||
|
%R Comp. Sci. Tech. Rep. No. 39
|
||||||
|
|
||||||
|
%T Yacc: Yet Another Compiler Compiler
|
||||||
|
%A S. C. Johnson
|
||||||
|
%I Bell Laboratories
|
||||||
|
%D 1975
|
||||||
|
%C Murray Hill, New Jersey
|
||||||
|
%R Comp. Sci. Tech. Rep. No. 32
|
||||||
|
|
||||||
|
%T The C Programming Language
|
||||||
|
%A B. W. Kernighan
|
||||||
|
%A D. M. Ritchie
|
||||||
|
%I Prentice-Hall, Inc.
|
||||||
|
%C Englewood Cliffs, New Jersey
|
||||||
|
%D 1978
|
||||||
|
|
||||||
|
%A M. Griffiths
|
||||||
|
%T LL(1) Grammars and Analysers
|
||||||
|
%E F. L. Bauer and J. Eickel
|
||||||
|
%B Compiler Construction, An Advanced Course
|
||||||
|
%I Springer-Verlag
|
||||||
|
%C New York, N.Y.
|
||||||
|
%D 1974
|
||||||
|
|
||||||
|
%T Make - A Program for Maintaining Computer Programs
|
||||||
|
%A S. I. Feldman
|
||||||
|
%J Software - Practice and Experience
|
||||||
|
%V 10
|
||||||
|
%N 8
|
||||||
|
%P 255-265
|
||||||
|
%D August 1979
|
||||||
|
|
||||||
|
%T Methods for the Automatic Construction of Error Correcting Parsers
|
||||||
|
%A J. R\*:ohrich
|
||||||
|
%J Acta Informatica
|
||||||
|
%V 13
|
||||||
|
%P 115-139
|
||||||
|
%D 1980
|
||||||
2712
doc/LLgen/LLgen_NCER.n
Normal file
2712
doc/LLgen/LLgen_NCER.n
Normal file
File diff suppressed because it is too large
Load Diff
15
doc/LLgen/Makefile
Normal file
15
doc/LLgen/Makefile
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
# $Id$
|
||||||
|
|
||||||
|
GRAP=grap
|
||||||
|
PIC=pic
|
||||||
|
EQN=eqn
|
||||||
|
REFER=refer
|
||||||
|
TBL=tbl
|
||||||
|
|
||||||
|
all: ../LLgen.doc ../LLgen_NCER.doc
|
||||||
|
|
||||||
|
../LLgen.doc: LLgen.n LLgen.refs
|
||||||
|
$(REFER) -sA+T -p LLgen.refs LLgen.n | $(EQN) | $(TBL) > $@
|
||||||
|
|
||||||
|
../LLgen_NCER.doc: LLgen_NCER.n
|
||||||
|
$(GRAP) LLgen_NCER.n | pic | eqn > $@
|
||||||
20
doc/LLgen/proto.make
Normal file
20
doc/LLgen/proto.make
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
# $Id$
|
||||||
|
|
||||||
|
#PARAMS do not remove this line!
|
||||||
|
|
||||||
|
SRC_DIR = $(SRC_HOME)/doc/LLgen
|
||||||
|
|
||||||
|
GRAP=grap
|
||||||
|
PIC=pic
|
||||||
|
EQN=eqn
|
||||||
|
REFER=refer
|
||||||
|
TBL=tbl
|
||||||
|
|
||||||
|
all: $(TARGET_HOME)/doc/LLgen.doc $(TARGET_HOME)/doc/LLgen_NCER.doc
|
||||||
|
|
||||||
|
$(TARGET_HOME)/doc/LLgen.doc: $(SRC_DIR)/LLgen.n $(SRC_DIR)/LLgen.refs
|
||||||
|
$(REFER) -sA+T -p $(SRC_DIR)/LLgen.refs $(SRC_DIR)/LLgen.n | $(EQN) | $(TBL) > $@
|
||||||
|
|
||||||
|
$(TARGET_HOME)/doc/LLgen_NCER.doc: $(SRC_DIR)/LLgen_NCER.n
|
||||||
|
$(GRAP) $(SRC_DIR)/LLgen_NCER.n | pic | eqn > $@
|
||||||
|
|
||||||
82
doc/Makefile
Normal file
82
doc/Makefile
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
# $Id$
|
||||||
|
|
||||||
|
# This Makefile is not supposed to be used in the doc source directory.
|
||||||
|
# Instead, it is supposed to be copied to the target doc directory.
|
||||||
|
|
||||||
|
SUF=dit
|
||||||
|
PRINT=dis
|
||||||
|
NROFF=troff
|
||||||
|
MS=-ms
|
||||||
|
OPR=dip
|
||||||
|
|
||||||
|
RESFILES= \
|
||||||
|
toolkit.$(SUF) install.$(SUF) em.$(SUF) ack.$(SUF) v7bugs.$(SUF) \
|
||||||
|
peep.$(SUF) cg.$(SUF) ncg.$(SUF) regadd.$(SUF) LLgen.$(SUF) \
|
||||||
|
basic.$(SUF) crefman.$(SUF) pascal.$(SUF) pcref.$(SUF) val.$(SUF) \
|
||||||
|
ansi_C.$(SUF) \
|
||||||
|
6500.$(SUF) i80.$(SUF) z80.$(SUF) top.$(SUF) ego.$(SUF) \
|
||||||
|
m68020.$(SUF) occam.$(SUF) m2ref.$(SUF) ceg.$(SUF) nopt.$(SUF) \
|
||||||
|
sparc.$(SUF) int.$(SUF) lint.$(SUF)
|
||||||
|
|
||||||
|
.SUFFIXES: .doc .$(SUF) .lpr .out
|
||||||
|
|
||||||
|
.doc.$(SUF):
|
||||||
|
$(NROFF) $(MS) $< > $@
|
||||||
|
|
||||||
|
# directly to the printer:
|
||||||
|
.doc.lpr:
|
||||||
|
$(NROFF) $(MS) $< | $(OPR)
|
||||||
|
|
||||||
|
# to standard output
|
||||||
|
.doc.out:
|
||||||
|
@$(NROFF) $(MS) $<
|
||||||
|
|
||||||
|
# Exceptions, to be run without -ms
|
||||||
|
|
||||||
|
v7bugs.$(SUF): v7bugs.doc
|
||||||
|
$(NROFF) v7bugs.doc >$@
|
||||||
|
|
||||||
|
v7bugs.lpr: v7bugs.doc
|
||||||
|
$(NROFF) v7bugs.doc | $(OPR)
|
||||||
|
|
||||||
|
v7bugs.out: v7bugs.doc
|
||||||
|
@$(NROFF) v7bugs.doc
|
||||||
|
|
||||||
|
pcref.$(SUF): pcref.doc
|
||||||
|
$(NROFF) pcref.doc >$@
|
||||||
|
|
||||||
|
pcref.lpr: pcref.doc
|
||||||
|
$(NROFF) pcref.doc | $(OPR)
|
||||||
|
|
||||||
|
pcref.out: pcref.doc
|
||||||
|
@$(NROFF) pcref.doc
|
||||||
|
|
||||||
|
val.$(SUF): val.doc
|
||||||
|
$(NROFF) val.doc >$@
|
||||||
|
|
||||||
|
val.lpr: val.doc
|
||||||
|
$(NROFF) val.doc | $(OPR)
|
||||||
|
|
||||||
|
val.out: val.doc
|
||||||
|
@$(NROFF) val.doc
|
||||||
|
|
||||||
|
pr:
|
||||||
|
@make "SUF="$(SUF) "NROFF="$(NROFF) "MS="$(MS) \
|
||||||
|
$(RESFILES) >make.pr.out 2>&1
|
||||||
|
@$(PRINT) $(RESFILES)
|
||||||
|
|
||||||
|
# The 'opr' entry creates a lot of paper ... but the user must be able
|
||||||
|
# to write the doc directory. I hope that this limits the users of
|
||||||
|
# this entry to persons that know what they are doing.
|
||||||
|
opr:
|
||||||
|
@make "SUF="$(SUF) "NROFF="$(NROFF) "MS="$(MS) $(RESFILES)
|
||||||
|
$(OPR) $(RESFILES)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
-rm -f $(RESFILES)
|
||||||
|
|
||||||
|
# The distr entry is only used when making a distribution tree.
|
||||||
|
# It makes a version of the installation manual, suitable for a simple
|
||||||
|
# line printer.
|
||||||
|
distr: install.doc
|
||||||
|
tbl install.doc | nroff -Tlp $(MS) >install.pr
|
||||||
8
doc/READ_ME
Normal file
8
doc/READ_ME
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
Some of these documents use a font called CW.
|
||||||
|
If this font is not available, reference to it can be changed with
|
||||||
|
a sed-script like
|
||||||
|
s/\.ft CW/.ft yourfont/
|
||||||
|
s/\\f(CW/\\fyourfont/g
|
||||||
|
s/^.fp\(.*\)CW$/.fp\1yourfont/
|
||||||
|
However, the font must be a constant-width font for the documents to look
|
||||||
|
reasonable.
|
||||||
444
doc/ack.doc
Normal file
444
doc/ack.doc
Normal file
@ -0,0 +1,444 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.nr PD 1v
|
||||||
|
.tr ~
|
||||||
|
.TL
|
||||||
|
Ack Description File
|
||||||
|
.br
|
||||||
|
Reference Manual
|
||||||
|
.AU
|
||||||
|
Ed Keizer
|
||||||
|
.AI
|
||||||
|
Vakgroep Informatica
|
||||||
|
Vrije Universiteit
|
||||||
|
Amsterdam
|
||||||
|
.NH
|
||||||
|
Introduction
|
||||||
|
.PP
|
||||||
|
The program \fIack\fP(I) internally maintains a table of
|
||||||
|
possible transformations and a table of string variables.
|
||||||
|
The transformation table contains one entry for each possible
|
||||||
|
transformation of a file.
|
||||||
|
Which transformations are used depends on the suffix of the
|
||||||
|
source file.
|
||||||
|
Each transformation table entry tells which input suffixes are
|
||||||
|
allowed and what suffix/name the output file has.
|
||||||
|
When the output file does not already satisfy the request of the
|
||||||
|
user (indicated with the flag \fB\-c.suffix\fP), the table is scanned
|
||||||
|
starting with the next transformation in the table for another
|
||||||
|
transformation that has as input suffix the output suffix of
|
||||||
|
the previous transformation.
|
||||||
|
A few special transformations are recognized, among them is the
|
||||||
|
combiner, which is
|
||||||
|
a program combining several files into one.
|
||||||
|
When no stop suffix was specified (flag \fB\-c.suffix\fP) \fIack\fP
|
||||||
|
stops after executing the combiner with as arguments the \-
|
||||||
|
possibly transformed \- input files and libraries.
|
||||||
|
\fIAck\fP will only perform the transformations in the order in
|
||||||
|
which they are presented in the table.
|
||||||
|
.LP
|
||||||
|
The string variables are used while creating the argument list
|
||||||
|
and program call name for
|
||||||
|
a particular transformation.
|
||||||
|
.NH
|
||||||
|
Which descriptions are used
|
||||||
|
.PP
|
||||||
|
\fIAck\fP always uses two description files: one to define the
|
||||||
|
front-end transformations and one for the machine dependent
|
||||||
|
back-end transformations.
|
||||||
|
Each description has a name.
|
||||||
|
First the way of determining
|
||||||
|
the name of the descriptions needed is described.
|
||||||
|
.PP
|
||||||
|
When the shell environment variable ACKFE is set \fIack\fP uses
|
||||||
|
that to determine the front-end table name, otherwise it uses
|
||||||
|
\fBfe\fP.
|
||||||
|
.PP
|
||||||
|
The way the backend table name is determined is more
|
||||||
|
convoluted.
|
||||||
|
.br
|
||||||
|
First, when the last filename in the program call name is not
|
||||||
|
one of \fIack\fP or the front-end call-names,
|
||||||
|
this filename is used as the backend description name.
|
||||||
|
Second, when the \fB\-m\fP is present the \fB\-m\fP is chopped of this
|
||||||
|
flag and the rest is used as the backend description name.
|
||||||
|
Third, when both failed the shell environment variable ACKM is
|
||||||
|
used.
|
||||||
|
Last, when also ACKM was not present the default backend is
|
||||||
|
used, determined by the definition of ACKM in h/local.h.
|
||||||
|
The presence and value of the definition of ACKM is
|
||||||
|
determined at compile time of \fIack\fP.
|
||||||
|
.PP
|
||||||
|
Now, we have the names, but that is only the first step.
|
||||||
|
\fIAck\fP stores a few descriptions at compile time.
|
||||||
|
This descriptions are simply files read in at compile time.
|
||||||
|
At the moment of writing this document, the descriptions
|
||||||
|
included are: pdp, fe, i86, m68k2, vax2 and int.
|
||||||
|
The name of a description is first searched for internally,
|
||||||
|
then in lib/descr/\fIname\fP, then in
|
||||||
|
lib/\fIname\fP/descr, and finally in the current
|
||||||
|
directory of the user.
|
||||||
|
.NH
|
||||||
|
Using the description file
|
||||||
|
.PP
|
||||||
|
Before starting on a narrative of the description file,
|
||||||
|
the introduction of a few terms is necessary.
|
||||||
|
All these terms are used to describe the scanning of zero
|
||||||
|
terminated strings, thereby producing another string or
|
||||||
|
sequence of strings.
|
||||||
|
.IP Backslashing 5
|
||||||
|
.br
|
||||||
|
All characters preceded by \e are modified to prevent
|
||||||
|
recognition at further scanning.
|
||||||
|
This modification is undone before a string is passed to the
|
||||||
|
outside world as argument or message.
|
||||||
|
When reading the description files the
|
||||||
|
sequences \e\e, \e# and \e<newline> have a special meaning.
|
||||||
|
\e\e translates to a single \e, \e# translates to a single #
|
||||||
|
that is not
|
||||||
|
recognized as the start of comment, but can be used in
|
||||||
|
recognition and finally, \e<newline> translates to nothing at
|
||||||
|
all, thereby allowing continuation lines.
|
||||||
|
.nr PD 0
|
||||||
|
.IP "Variable replacement"
|
||||||
|
.br
|
||||||
|
The scan recognizes the sequences {{, {NAME} and {NAME?text}
|
||||||
|
Where NAME can be any combination if characters excluding ? and
|
||||||
|
} and text may be anything excluding }.
|
||||||
|
(~\e} is allowed of course~)
|
||||||
|
The first sequence produces an unescaped single {.
|
||||||
|
The second produces the contents of the NAME, definitions are
|
||||||
|
done by \fIack\fP and in description files.
|
||||||
|
When the NAME is not defined an error message is produced on
|
||||||
|
the diagnostic output.
|
||||||
|
The last sequence produces the contents of NAME if it is
|
||||||
|
defined and text otherwise.
|
||||||
|
.PP
|
||||||
|
.IP "Expression replacement"
|
||||||
|
.br
|
||||||
|
Syntax: (\fIsuffix sequence\fP:\fIsuffix sequence\fP=\fItext\fP)
|
||||||
|
.br
|
||||||
|
Example: (.c.p.e:.e=tail_em)
|
||||||
|
.br
|
||||||
|
If the two suffix sequences have a common member \-~\&.e in this
|
||||||
|
case~\- the text is produced.
|
||||||
|
When no common member is present the empty string is produced.
|
||||||
|
Thus the example given is a constant expression.
|
||||||
|
Normally, one of the suffix sequences is produced by variable
|
||||||
|
replacement.
|
||||||
|
\fIAck\fP sets three variables while performing the diverse
|
||||||
|
transformations: HEAD, TAIL and RTS.
|
||||||
|
All three variables depend on the properties \fIrts\fP and
|
||||||
|
\fIneed\fP from the transformations used.
|
||||||
|
Whenever a transformation is used for the first time,
|
||||||
|
the text following the \fIneed\fP is appended to both the HEAD and
|
||||||
|
TAIL variable.
|
||||||
|
The value of the variable RTS is determined by the first
|
||||||
|
transformation used with a \fIrts\fP property.
|
||||||
|
.IP
|
||||||
|
Two runtime flags have effect on the value of one or more of
|
||||||
|
these variables.
|
||||||
|
The flag \fB\-.suffix\fP has the same effect on these three variables
|
||||||
|
as if a file with that \fBsuffix\fP was included in the argument list
|
||||||
|
and had to be translated.
|
||||||
|
The flag \fB\-r.suffix\fP only has that effect on the TAIL
|
||||||
|
variable.
|
||||||
|
The program call names \fIacc\fP and \fIcc\fP have the effect
|
||||||
|
of an automatic \fB\-.c\fP flag.
|
||||||
|
\fIApc\fP and \fIpc\fP have the effect of an automatic \fB\-.p\fP flag.
|
||||||
|
.IP "Line splitting"
|
||||||
|
.br
|
||||||
|
The string is transformed into a sequence of strings by replacing
|
||||||
|
the blank space by string separators (nulls).
|
||||||
|
.IP "IO replacement"
|
||||||
|
.br
|
||||||
|
The > in the string is replaced by the output file name.
|
||||||
|
The < in the string is replaced by the input file name.
|
||||||
|
When multiple input files are present the string is duplicated
|
||||||
|
for each input file name.
|
||||||
|
.nr PD 1v
|
||||||
|
.LP
|
||||||
|
Each description is a sequence of variable definitions followed
|
||||||
|
by a sequence of transformation definitions.
|
||||||
|
Variable definitions use a line each, transformations
|
||||||
|
definitions consist of a sequence of lines.
|
||||||
|
Empty lines are discarded, as are lines with nothing but
|
||||||
|
comment.
|
||||||
|
Comment is started by a # character, and continues to the end
|
||||||
|
of the line.
|
||||||
|
Three special two-characters sequences exist: \e#, \e\e and
|
||||||
|
\e<newline>.
|
||||||
|
Their effect is described under 'backslashing' above.
|
||||||
|
Each \- nonempty \- line starts with a keyword, possibly
|
||||||
|
preceded by blank space.
|
||||||
|
The keyword can be followed by a further specification.
|
||||||
|
The two are separated by blank space.
|
||||||
|
.PP
|
||||||
|
Variable definitions use the keyword \fIvar\fP and look like this:
|
||||||
|
.DS X
|
||||||
|
var NAME=text
|
||||||
|
.DE
|
||||||
|
The name can be any identifier, the text may contain any
|
||||||
|
character.
|
||||||
|
Blank space before the equal sign is not part of the NAME.
|
||||||
|
Blank space after the equal is considered as part of the text.
|
||||||
|
The text is scanned for variable replacement before it is
|
||||||
|
associated with the variable name.
|
||||||
|
.br
|
||||||
|
.sp 2
|
||||||
|
The start of a transformation definition is indicated by the
|
||||||
|
keyword \fIname\fP.
|
||||||
|
The last line of such a definition contains the keyword
|
||||||
|
\fIend\fP.
|
||||||
|
The lines in between associate properties to a transformation
|
||||||
|
and may be presented in any order.
|
||||||
|
The identifier after the \fIname\fP keyword determines the name
|
||||||
|
of the transformation.
|
||||||
|
This name is used for debugging and by the \fB\-R\fP flag.
|
||||||
|
The keywords are used to specify which input suffices are
|
||||||
|
recognized by that transformation,
|
||||||
|
the program to run, the arguments to be handed to that program
|
||||||
|
and the name or suffix of the resulting output file.
|
||||||
|
Two keywords are used to indicate which run-time startoffs and
|
||||||
|
libraries are needed.
|
||||||
|
The possible keywords are:
|
||||||
|
.IP \fIfrom\fP
|
||||||
|
.br
|
||||||
|
followed by a sequence of suffices.
|
||||||
|
Each file with one of these suffices is allowed as input file.
|
||||||
|
Preprocessor transformations do not need the \fIfrom\fP
|
||||||
|
keyword. All other transformations do.
|
||||||
|
.nr PD 0
|
||||||
|
.IP \fIto\fP
|
||||||
|
.br
|
||||||
|
followed by the suffix of the output file name or in the case of a
|
||||||
|
linker
|
||||||
|
the output file name.
|
||||||
|
.IP \fIprogram\fP
|
||||||
|
.br
|
||||||
|
followed by name of the load file of the program, a pathname most likely
|
||||||
|
starts with either a / or {EM}.
|
||||||
|
This keyword must be
|
||||||
|
present, the remainder of the line
|
||||||
|
is subject to backslashing and variable replacement.
|
||||||
|
.IP \fImapflag\fP
|
||||||
|
.br
|
||||||
|
The mapflags are used to grab flags given to \fIack\fP and
|
||||||
|
pass them on to a specific transformation.
|
||||||
|
This feature uses a few simple pattern matching and replacement
|
||||||
|
facilities.
|
||||||
|
Multiple occurrences of this keyword are allowed.
|
||||||
|
This text following the keyword is
|
||||||
|
subjected to backslashing.
|
||||||
|
The keyword is followed by a match expression and a variable
|
||||||
|
assignment separated by blank space.
|
||||||
|
As soon as both description files are read, \fIack\fP looks
|
||||||
|
at all transformations in these files to find a match for the
|
||||||
|
flags given to \fIack\fP.
|
||||||
|
The flags \fB\-m\fP, \fB\-o\fP,
|
||||||
|
\fB\-O\fP, \fB\-r\fP, \fB\-v\fP, \fB\-g\fP, \-\fB\-c\fP, \fB\-t\fP,
|
||||||
|
\fB\-k\fP, \fB\-R\fP and \-\fB\-.\fP are specific to \fIack\fP and
|
||||||
|
not handed down to any transformation.
|
||||||
|
The matching is performed in the order in which the entries
|
||||||
|
appear in the definition.
|
||||||
|
The scanning stops after first match is found.
|
||||||
|
When a match is found, the variable assignment is executed.
|
||||||
|
A * in the match expression matches any sequence of characters,
|
||||||
|
a * in the right hand part of the assignment is
|
||||||
|
replaced by the characters matched by
|
||||||
|
the * in the expression.
|
||||||
|
The right hand part is also subject to variable replacement.
|
||||||
|
The variable will probably be used in the program arguments.
|
||||||
|
The \fB\-l\fP flags are special,
|
||||||
|
the order in which they are presented to \fIack\fP must be
|
||||||
|
preserved.
|
||||||
|
The identifier LNAME is used in conjunction with the scanning of
|
||||||
|
\fB\-l\fP flags.
|
||||||
|
The value assigned to LNAME is used to replace the flag.
|
||||||
|
The example further on shows the use of all this.
|
||||||
|
.IP \fIargs\fP
|
||||||
|
.br
|
||||||
|
The keyword is followed by the program call arguments.
|
||||||
|
It is subject to backslashing, variable replacement, expression
|
||||||
|
replacement, line splitting and IO replacement.
|
||||||
|
The variables assigned to by \fImapflags\fP will probably be
|
||||||
|
used here.
|
||||||
|
The flags not recognized by \fIack\fP or any of the transformations
|
||||||
|
are passed to the linker and inserted before all other arguments.
|
||||||
|
.IP \fIstdin\fP
|
||||||
|
.br
|
||||||
|
This keyword indicates that the transformation reads from standard input.
|
||||||
|
.IP \fIstdout\fP
|
||||||
|
.br
|
||||||
|
This keyword indicates that the transformation writes on standard output.
|
||||||
|
.IP \fIoptimizer\fP
|
||||||
|
.br
|
||||||
|
The presence of this keyword indicates that this transformation is an optimizer.
|
||||||
|
It can be followed by a number, indicating the "level" of the
|
||||||
|
optimizer (see description of the -O option in the ack(1ACK) manual page).
|
||||||
|
.IP \fIpriority\fP
|
||||||
|
.br
|
||||||
|
This \-~optional~\- keyword is followed by a number. Positive priority means
|
||||||
|
that the transformation is likely to be used, negative priority means that
|
||||||
|
the transformation is unlikely to be used.
|
||||||
|
Priorities can also be set with a ack(1ACK) command line option.
|
||||||
|
Priorities come in handy when there are several implementations of a
|
||||||
|
certain transformation. They can then be used to select a default one.
|
||||||
|
.IP \fIlinker\fP
|
||||||
|
.br
|
||||||
|
This keyword indicates that this transformation is the linker.
|
||||||
|
.IP \fIcombiner\fP
|
||||||
|
.br
|
||||||
|
This keyword indicates that this transformation is a combiner. A combiner
|
||||||
|
is a program combining several files into one, but is not a linker.
|
||||||
|
An example of a combiner is the global optimizer.
|
||||||
|
.IP \fIprep\fP
|
||||||
|
.br
|
||||||
|
This \-~optional~\- keyword is followed an option indicating its relation
|
||||||
|
to the preprocessor.
|
||||||
|
The possible options are:
|
||||||
|
.DS X
|
||||||
|
always the input files must be preprocessed
|
||||||
|
cond the input files must be preprocessed when starting with #
|
||||||
|
is this transformation is the preprocessor
|
||||||
|
.DE
|
||||||
|
.IP \fIrts\fP
|
||||||
|
.br
|
||||||
|
This \-~optional~\- keyword indicates that the rest of the line must be
|
||||||
|
used to set the variable RTS, if it was not already set.
|
||||||
|
Thus the variable RTS is set by the first transformation
|
||||||
|
executed which such a property or as a result from \fIack\fP's program
|
||||||
|
call name (acc, cc, apc or pc) or by the \fB\-.suffix\fP flag.
|
||||||
|
.IP \fIneed\fP
|
||||||
|
.br
|
||||||
|
This \-~optional~\- keyword indicates that the rest of the line must be
|
||||||
|
concatenated to the HEAD and TAIL variables.
|
||||||
|
This is done once for every transformation used or indicated
|
||||||
|
by one of the program call names mentioned above or indicated
|
||||||
|
by the \fB\-.suffix\fP flag.
|
||||||
|
.br
|
||||||
|
.nr PD 1v
|
||||||
|
.NH
|
||||||
|
Conventions used in description files
|
||||||
|
.PP
|
||||||
|
\fIAck\fP reads two description files.
|
||||||
|
A few of the variables defined in the machine specific file
|
||||||
|
are used by the descriptions of the front-ends.
|
||||||
|
Other variables, set by \fIack\fP, are of use to all
|
||||||
|
transformations.
|
||||||
|
.PP
|
||||||
|
\fIAck\fP sets the variable EM to the home directory of the
|
||||||
|
Amsterdam Compiler Kit.
|
||||||
|
The variable SOURCE is set to the name of the argument that is currently
|
||||||
|
being massaged, this is useful for debugging.
|
||||||
|
The variable SUFFIX is set to the suffix of the argument that is
|
||||||
|
currently being massaged.
|
||||||
|
.br
|
||||||
|
The variable M indicates the
|
||||||
|
directory in lib/{M}/tail_..... and NAME is the string to
|
||||||
|
be defined by the preprocessor with \-D{NAME}.
|
||||||
|
The definitions of {w}, {s}, {l}, {d}, {f} and {p} indicate
|
||||||
|
EM_WSIZE, EM_SSIZE, EM_LSIZE, EM_DSIZE, EM_FSIZE and EM_PSIZE
|
||||||
|
respectively.
|
||||||
|
.br
|
||||||
|
The variable INCLUDES is used as the last argument to \fIcpp\fP.
|
||||||
|
It is used to add directories to
|
||||||
|
the list of directories containing #include files.
|
||||||
|
.PP
|
||||||
|
The variables HEAD, TAIL and RTS are set by \fIack\fP and used
|
||||||
|
to compose the arguments for the linker.
|
||||||
|
.NH
|
||||||
|
Example
|
||||||
|
.PP
|
||||||
|
Description for front-end
|
||||||
|
.DS X
|
||||||
|
.ta 4n 40n
|
||||||
|
name cpp # the C-preprocessor
|
||||||
|
# no from, it's governed by the P property
|
||||||
|
to .i # result files have suffix i
|
||||||
|
program {EM}/lib/cpp # pathname of loadfile
|
||||||
|
mapflag \-I* CPP_F={CPP_F?} \-I* # grab \-I.. \-U.. and
|
||||||
|
mapflag \-U* CPP_F={CPP_F?} \-U* # \-D.. to use as arguments
|
||||||
|
mapflag \-D* CPP_F={CPP_F?} \-D* # in the variable CPP_F
|
||||||
|
args {CPP_F?} {INCLUDES?} \-D{NAME} \-DEM_WSIZE={w} \-DEM_PSIZE={p} \e
|
||||||
|
\-DEM_SSIZE={s} \-DEM_LSIZE={l} \-DEM_FSIZE={f} \-DEM_DSIZE={d} <
|
||||||
|
# The arguments are: first the \-[IUD]...
|
||||||
|
# then the include dir's for this machine
|
||||||
|
# then the NAME and size values finally
|
||||||
|
# followed by the input file name
|
||||||
|
stdout # Output on stdout
|
||||||
|
prep is # Is preprocessor
|
||||||
|
end
|
||||||
|
name cem # the C-compiler proper
|
||||||
|
from .c # used for files with suffix .c
|
||||||
|
to .k # produces compact code files
|
||||||
|
program {EM}/lib/em_cem # pathname of loadfile
|
||||||
|
mapflag \-p CEM_F={CEM_F?} \-Xp # pass \-p as \-Xp to cem
|
||||||
|
mapflag \-L CEM_F={CEM_F?} \-l # pass \-L as \-l to cem
|
||||||
|
args \-Vw{w}i{w}p{p}f{f}s{s}l{l}d{d} {CEM_F?}
|
||||||
|
# the arguments are the object sizes in
|
||||||
|
# the \-V... flag and possibly \-l and \-Xp
|
||||||
|
stdin # input from stdin
|
||||||
|
stdout # output on stdout
|
||||||
|
prep always # use cpp
|
||||||
|
rts .c # use the C run-time system
|
||||||
|
need .c # use the C libraries
|
||||||
|
end
|
||||||
|
name decode # make human readable files from compact code
|
||||||
|
from .k.m # accept files with suffix .k or .m
|
||||||
|
to .e # produce .e files
|
||||||
|
program {EM}/lib/em_decode # pathname of loadfile
|
||||||
|
args < # the input file name is the only argument
|
||||||
|
stdout # the output comes on stdout
|
||||||
|
end
|
||||||
|
.DE
|
||||||
|
|
||||||
|
.DS X
|
||||||
|
.ta 4n 40n
|
||||||
|
Example of a backend, in this case the EM assembler/loader.
|
||||||
|
|
||||||
|
var w=2 # wordsize 2
|
||||||
|
var p=2 # pointersize 2
|
||||||
|
var s=2 # short size 2
|
||||||
|
var l=4 # long size 4
|
||||||
|
var f=4 # float size 4
|
||||||
|
var d=8 # double size 8
|
||||||
|
var M=em22
|
||||||
|
var NAME=em22 # for cpp (NAME=em22 results in #define em22 1)
|
||||||
|
var LIB=lib/{M}/tail_ # part of file name for libraries
|
||||||
|
var RT=lib/{M}/head_ # part of file name for run-time startoff
|
||||||
|
var SIZE_FLAG=\-sm # default internal table size flag
|
||||||
|
var INCLUDES=\-I{EM}/include # use {EM}/include for #include files
|
||||||
|
name asld # Assembler/loader
|
||||||
|
from .k.m.a # accepts compact code and archives
|
||||||
|
to e.out # output file name
|
||||||
|
program {EM}/lib/em_ass # load file pathname
|
||||||
|
mapflag \-l* LNAME={EM}/{LIB}* # e.g. \-ly becomes
|
||||||
|
# {EM}/mach/int/lib/tail_y
|
||||||
|
mapflag \-+* ASS_F={ASS_F?} \-+* # recognize \-+ and \-\-
|
||||||
|
mapflag \-\-* ASS_F={ASS_F?} \-\-*
|
||||||
|
mapflag \-s* SIZE_FLAG=\-s* # overwrite old value of SIZE_FLAG
|
||||||
|
args {SIZE_FLAG} \e
|
||||||
|
({RTS}:.c={EM}/{RT}cc) ({RTS}:.p={EM}/{RT}pc) \-o > < \e
|
||||||
|
(.p:{TAIL}={EM}/{LIB}pc) \e
|
||||||
|
(.c:{TAIL}={EM}/{LIB}cc.1s {EM}/{LIB}cc.2g) \e
|
||||||
|
(.c.p:{TAIL}={EM}/{LIB}mon)
|
||||||
|
# \-s[sml] must be first argument
|
||||||
|
# the next line contains the choice for head_cc or head_pc
|
||||||
|
# and the specification of in- and output.
|
||||||
|
# the last three args lines choose libraries
|
||||||
|
linker
|
||||||
|
end
|
||||||
|
.DE
|
||||||
|
|
||||||
|
The command \fIack \-mem22 \-v \-v \-I../h \-L \-ly prog.c\fP
|
||||||
|
would result in the following
|
||||||
|
calls (with exec(II)):
|
||||||
|
.DS X
|
||||||
|
.ta 4n
|
||||||
|
1) /lib/cpp \-I../h \-I/usr/em/include \-Dem22 \-DEM_WSIZE=2 \-DEM_PSIZE=2 \e
|
||||||
|
\-DEM_SSIZE=2 \-DEM_LSIZE=4 \-DEM_FSIZE=4 \-DEM_DSIZE=8 prog.c
|
||||||
|
2) /usr/em/lib/em_cem \-Vw2i2p2f4s2l4d8 \-l
|
||||||
|
3) /usr/em/lib/em_ass \-sm /usr/em/lib/em22/head_cc \-o e.out prog.k
|
||||||
|
/usr/em/lib/em22/tail_y /usr/em/lib/em22/tail_cc.1s
|
||||||
|
/usr/em/lib/em22/tail_cc.2g /usr/em/lib/em22/tail_mon
|
||||||
|
.DE
|
||||||
365
doc/ansi_C.doc
Executable file
365
doc/ansi_C.doc
Executable file
@ -0,0 +1,365 @@
|
|||||||
|
.de NS
|
||||||
|
.sp
|
||||||
|
.in 0
|
||||||
|
\\fBANS \\$1:\\fP
|
||||||
|
..
|
||||||
|
.TL
|
||||||
|
Amsterdam Compiler Kit-ANSI C compiler compliance statements
|
||||||
|
.AU
|
||||||
|
Hans van Eck
|
||||||
|
.AI
|
||||||
|
Dept. of Mathematics and Computer Science
|
||||||
|
Vrije Universiteit
|
||||||
|
Amsterdam, The Netherlands
|
||||||
|
.PP
|
||||||
|
This document specifies the implementation-defined behaviour of the ANSI-C
|
||||||
|
front end of the Amsterdam Compiler Kit as required by ANS X3.159-1989. Since
|
||||||
|
the implementation-defined behaviour sometimes depends on the machine
|
||||||
|
compiling on or for, some items will be left unspecified in this
|
||||||
|
document\(dg.
|
||||||
|
.FS
|
||||||
|
\(dg when cross-compiling, run-time behaviour may be different from
|
||||||
|
compile-time behaviour
|
||||||
|
.FE
|
||||||
|
The compiler assumes that it runs on a UNIX system.
|
||||||
|
.NS A.6.3.1
|
||||||
|
.IP -
|
||||||
|
Diagnostics are placed on the standard error output. They have the
|
||||||
|
following specification:
|
||||||
|
.br
|
||||||
|
"<file>", line <nr>: [(<class>)] <diagnostic>
|
||||||
|
.br
|
||||||
|
There are three classes of diagnostics: "error", "strict" and "warning".
|
||||||
|
When the class is "error", the <class> is absent.
|
||||||
|
.br
|
||||||
|
The class "strict" is used for violations of the standard which are
|
||||||
|
not severe enough to stop compilation. An example is the the occurrence
|
||||||
|
of non white-space after an '#else' or '#endif' pre-processing
|
||||||
|
directive. The class "warning" is used for legal but dubious
|
||||||
|
constructions. An example is overflow of constant expressions.
|
||||||
|
.NS A.6.3.2
|
||||||
|
.IP -
|
||||||
|
The function 'main' can have two arguments. The first argument is an
|
||||||
|
integer specifying the number of arguments on the command line. The second
|
||||||
|
argument is a pointer to an array of pointers to the arguments (as
|
||||||
|
strings).
|
||||||
|
.IP -
|
||||||
|
Interactive devices are terminals.
|
||||||
|
.NS A.6.3.3
|
||||||
|
.IP -
|
||||||
|
The number of significant characters is an option. By default it is 64.
|
||||||
|
There is a distinction between upper and lower case.
|
||||||
|
.NS A.6.3.4
|
||||||
|
.IP -
|
||||||
|
The compiler assumes ASCII-characters in both the source and execution
|
||||||
|
character set.
|
||||||
|
.IP -
|
||||||
|
There are no multi-byte characters.
|
||||||
|
.IP -
|
||||||
|
There 8 bits in a character.
|
||||||
|
.IP -
|
||||||
|
Character constants with values that can not be represented in 8 bits
|
||||||
|
are truncated.
|
||||||
|
.IP -
|
||||||
|
Character constants that are more than 1 character wide will have the
|
||||||
|
first character specified in the least significant byte.
|
||||||
|
.IP -
|
||||||
|
The only supported locale is "C".
|
||||||
|
.IP -
|
||||||
|
A plain 'char' has the same range of values as 'signed char'.
|
||||||
|
.NS A.6.3.5
|
||||||
|
.IP -
|
||||||
|
The compiler assumes that it works on and compiles for a
|
||||||
|
2-complement binary-number system. Shorts will use 2 bytes and longs
|
||||||
|
will use 4 bytes. The size of integers are machine dependent.
|
||||||
|
.IP -
|
||||||
|
Converting an integer to a shorter signed integer is implemented by
|
||||||
|
ignoring the high-order byte(s) of the former.
|
||||||
|
Converting a unsigned integer to a signed integer of the same type is
|
||||||
|
only done in administration. This means that the bit-pattern remains
|
||||||
|
unchanged.
|
||||||
|
.IP -
|
||||||
|
The result of bitwise operations on signed integers are what can be
|
||||||
|
expected on a 2-complement machine.
|
||||||
|
.IP -
|
||||||
|
If either operand is negative, whether the result of the / operator is the
|
||||||
|
largest integer less than or equal to the algebraic quotient or the
|
||||||
|
smallest integer greater than or equal to the algebraic quotient is machine
|
||||||
|
dependent, as is the sign of the result of the % operator.
|
||||||
|
.IP -
|
||||||
|
The right-shift of a negative value is negative.
|
||||||
|
.NS A.6.3.6
|
||||||
|
.IP -
|
||||||
|
The representation of floating-point values is machine-dependent.
|
||||||
|
When native floating-point is not present an IEEE-emulation is used.
|
||||||
|
The compiler uses high-precision floating-point for constant folding.
|
||||||
|
.IP -
|
||||||
|
Truncation is always to the nearest floating-point number that can
|
||||||
|
be represented.
|
||||||
|
.NS A.6.3.7
|
||||||
|
.IP -
|
||||||
|
The type returned by the sizeof-operator (also known as size_t)
|
||||||
|
is 'unsigned int'. This is done for backward compatibility reasons.
|
||||||
|
.IP -
|
||||||
|
Casting an integer to a pointer or vice versa has no effect in
|
||||||
|
bit-pattern when the sizes are equal. Otherwise the value will be
|
||||||
|
truncated or zero-extended (depending on the direction of the
|
||||||
|
conversion and the relative sizes).
|
||||||
|
.IP -
|
||||||
|
When a pointer is as large as an integer, the type of a 'ptrdiff_t' will
|
||||||
|
be 'int'. Otherwise the type will be 'long'.
|
||||||
|
.NS A.6.3.8
|
||||||
|
.IP -
|
||||||
|
Since the front end has only limited control over the registers, it can
|
||||||
|
only make it more likely that variables that are declared as
|
||||||
|
registers also end up in registers. The only things that can possibly be
|
||||||
|
put into registers are : 'int', 'long', 'float', 'double', 'long double'
|
||||||
|
and pointers.
|
||||||
|
.NS A.6.3.9
|
||||||
|
.IP -
|
||||||
|
When a member of a union object is accessed using a member of a
|
||||||
|
different type, the resulting value will usually be garbage. The
|
||||||
|
compiler makes no effort to catch these errors.
|
||||||
|
.IP -
|
||||||
|
The alignment of types is a compile-time option. The alignment of
|
||||||
|
a structure-member is the alignment of its type. Usually, the
|
||||||
|
alignment is passed on to the compiler by the 'ack' program. When a
|
||||||
|
user wants to do this manually, he/she should be prepared for trouble.
|
||||||
|
.IP -
|
||||||
|
A "plain" 'int' bit-field is taken as a 'signed int'. This means that
|
||||||
|
a field with a size of 1 bit can only store the values 0 and -1.
|
||||||
|
.IP -
|
||||||
|
The order of allocation of bit-fields is a compile-time option. By
|
||||||
|
default, high-order bits are allocated first.
|
||||||
|
.IP -
|
||||||
|
An enum has the same size as a "plain" 'int'.
|
||||||
|
.NS A.6.3.10
|
||||||
|
.IP -
|
||||||
|
An access to a volatile declared variable is done by just mentioning
|
||||||
|
the variable. E.g. the statement "x;" where x is declared volatile,
|
||||||
|
constitutes an access.
|
||||||
|
.S A.6.3.11
|
||||||
|
.IP -
|
||||||
|
There is no fixed limit on the number of declarators that may modify an
|
||||||
|
arithmetic, structure or union type, although specifying too many may
|
||||||
|
cause the compiler to run out of memory.
|
||||||
|
.NS A.6.3.12
|
||||||
|
.IP -
|
||||||
|
The maximum number of cases in a switch-statement is in the order of
|
||||||
|
1e9, although the compiler may run out of memory somewhat earlier.
|
||||||
|
.NS A.6.3.13
|
||||||
|
.IP -
|
||||||
|
Since both the pre-processor and the compiler assume ASCII-characters,
|
||||||
|
a single character constant in a conditional-inclusion directive
|
||||||
|
matches the same value in the execution character set.
|
||||||
|
.IP -
|
||||||
|
The pre-processor recognizes -I... command-line options. The
|
||||||
|
directories thus specified are searched first. After that, depending on the
|
||||||
|
command that the preprocessor is called with, machine/system-dependant
|
||||||
|
directories are searched. After that, ~em/include/_tail_ac and
|
||||||
|
/usr/include are visited.
|
||||||
|
.IP -
|
||||||
|
Quoted names are first looked for in the directory in which the file
|
||||||
|
which does the include resides.
|
||||||
|
.IP -
|
||||||
|
The characters in a h- or q- char-sequence are taken to be UNIX
|
||||||
|
paths.
|
||||||
|
.IP -
|
||||||
|
Neither the compiler nor the preprocessor know any pragmas.
|
||||||
|
.IP -
|
||||||
|
Since the compiler runs on UNIX, __DATE__ and __TIME__ will always be
|
||||||
|
defined.
|
||||||
|
.NS A.6.3.14
|
||||||
|
.IP -
|
||||||
|
NULL is defined as ((void *)0). This in order to flag dubious
|
||||||
|
constructions like "int x = NULL;".
|
||||||
|
.IP -
|
||||||
|
The diagnostic printed by 'assert' is as follows:
|
||||||
|
.ti +4n
|
||||||
|
"Assertion "<expr>" failed, file "<file>", line <line>",
|
||||||
|
.br
|
||||||
|
where <expr> is the argument to the assert macro, printed as string.
|
||||||
|
(the <file> and <line> should be clear)
|
||||||
|
.KS
|
||||||
|
.IP -
|
||||||
|
The sets for character test macros.
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
name: set:
|
||||||
|
isalnum() 0-9A-Za-z
|
||||||
|
isalpha() A-Za-z
|
||||||
|
iscntrl() \e000-\e037\e177
|
||||||
|
islower() a-z
|
||||||
|
isupper() A-Z
|
||||||
|
isprint() <space>-~ (== \e040-\e176)
|
||||||
|
.TE
|
||||||
|
.KE
|
||||||
|
As an addition, there is an isascii() macro, which tests whether a character
|
||||||
|
is an ascii character. Characters in the range from \e000 to \e177 are ascii
|
||||||
|
characters.
|
||||||
|
.KS
|
||||||
|
.IP -
|
||||||
|
The behaviour of mathematic functions on domain error:
|
||||||
|
.TS
|
||||||
|
l c
|
||||||
|
l n.
|
||||||
|
name: returns:
|
||||||
|
asin() 0.0
|
||||||
|
acos() 0.0
|
||||||
|
atan2() 0.0
|
||||||
|
fmod() 0.0
|
||||||
|
log() -HUGE_VAL
|
||||||
|
log10() -HUGE_VAL
|
||||||
|
pow() 0.0
|
||||||
|
sqrt() 0.0
|
||||||
|
.TE
|
||||||
|
.KE
|
||||||
|
.IP -
|
||||||
|
Underflow range errors do not cause errno to be set.
|
||||||
|
.IP -
|
||||||
|
The function fmod() returns 0.0 and sets errno to EDOM when the second
|
||||||
|
argument is 0.0.
|
||||||
|
.IP -
|
||||||
|
The set of signals for the signal() function depends on the UNIX-system
|
||||||
|
which the compiler is compiling for. The default handling, semantics
|
||||||
|
and behaviour of these signals are those specified by the operating
|
||||||
|
system vendor. The default handling is not reset when SIGILL is
|
||||||
|
received.
|
||||||
|
.IP -
|
||||||
|
A text-stream need not end in a new-line character.
|
||||||
|
.IP -
|
||||||
|
White space characters before a new-line appear when read in.
|
||||||
|
.IP -
|
||||||
|
There may be any number of null characters appended to a binary
|
||||||
|
stream.
|
||||||
|
.IP -
|
||||||
|
The file position indicator of an append mode stream is initially
|
||||||
|
positioned at the beginning of the file.
|
||||||
|
.IP -
|
||||||
|
A write on a text stream does not cause the associated file to be
|
||||||
|
truncated beyond that point.
|
||||||
|
.IP -
|
||||||
|
The buffering intended by the standard is fully supported.
|
||||||
|
.IP -
|
||||||
|
A zero-length file actually exists.
|
||||||
|
.IP -
|
||||||
|
A file name can consist of any character, except for the '\e0' and
|
||||||
|
the '/'.
|
||||||
|
.IP -
|
||||||
|
A file can be open multiple times.
|
||||||
|
.IP -
|
||||||
|
When a remove() is done on an open file, reading and writing behave
|
||||||
|
just as can be expected from a non-removed file. When the associated
|
||||||
|
stream is closed, all written data will be lost.
|
||||||
|
.IP -
|
||||||
|
When a file exists prior to a call to rename(), the behaviour is that
|
||||||
|
of the underlying UNIX system. Normally, the call would fail.
|
||||||
|
.IP -
|
||||||
|
The %p conversion in fprintf() has the same effect as %#x or %#lx,
|
||||||
|
depending on the sizes of pointer and integer.
|
||||||
|
.IP -
|
||||||
|
The %p conversion in fscanf() has the same effect as %x or %lx,
|
||||||
|
depending on the sizes of pointer and integer.
|
||||||
|
.IP -
|
||||||
|
A - character that is neither the first nor the last character in the
|
||||||
|
scanlist for %[ conversion is taken to be a range indicator. When the
|
||||||
|
first character has a higher ASCII-value than the second, the - will
|
||||||
|
just be put into the scanlist.
|
||||||
|
.IP -
|
||||||
|
The value of errno when fgetpos() or ftell() failed is that of lseek().
|
||||||
|
This means:
|
||||||
|
.RS
|
||||||
|
.IP "EBADF \-" 10
|
||||||
|
when the stream is not valid
|
||||||
|
.IP "ESPIPE \-"
|
||||||
|
when fildes is associated with a pipe (and on some systems: sockets)
|
||||||
|
.IP "EINVAL \-"
|
||||||
|
the resulting file pointer would be negative
|
||||||
|
.RE
|
||||||
|
.LP
|
||||||
|
.IP -
|
||||||
|
The messages generated by perror() depend on the value of errno.
|
||||||
|
The mapping of errors to strings is done by strerror().
|
||||||
|
.IP -
|
||||||
|
When the requested size is zero, malloc(), calloc() and realloc()
|
||||||
|
return a null-pointer.
|
||||||
|
.IP -
|
||||||
|
When abort() is called, output buffers will be flushed. Temporary files
|
||||||
|
(made with the tmpfile() function) will have disappeared when SIGABRT
|
||||||
|
is not caught or ignored.
|
||||||
|
.IP -
|
||||||
|
The exit() function returns the low-order eight bits of its argument
|
||||||
|
to the environment.
|
||||||
|
.IP -
|
||||||
|
The predefined environment names are controlled by the user.
|
||||||
|
Setting environment variables is done through the putenv() function.
|
||||||
|
This function accepts a pointer to char as its argument.
|
||||||
|
To set f.i. the environment variable TERM to a230 one writes
|
||||||
|
.ti +4n
|
||||||
|
putenv("TERM=a230");
|
||||||
|
.br
|
||||||
|
The argument to putenv() is stored in an internal table, so malloc'ed
|
||||||
|
strings can not be freed until another call to putenv() (which sets the
|
||||||
|
same environment variable) is made. The function returns 1 if it fails,
|
||||||
|
0 otherwise.
|
||||||
|
.LP
|
||||||
|
.IP -
|
||||||
|
The argument to system is passed as argument to /bin/sh -c.
|
||||||
|
.IP -
|
||||||
|
The strings returned by strerror() depend on errno in the following
|
||||||
|
way:
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
errno string
|
||||||
|
0 "Error 0",
|
||||||
|
EPERM "Not owner",
|
||||||
|
ENOENT "No such file or directory",
|
||||||
|
ESRCH "No such process",
|
||||||
|
EINTR "Interrupted system call",
|
||||||
|
EIO "I/O error",
|
||||||
|
ENXIO "No such device or address",
|
||||||
|
E2BIG "Arg list too long",
|
||||||
|
ENOEXEC "Exec format error",
|
||||||
|
EBADF "Bad file number",
|
||||||
|
ECHILD "No children",
|
||||||
|
EAGAIN "No more processes",
|
||||||
|
ENOMEM "Not enough core",
|
||||||
|
EACCES "Permission denied",
|
||||||
|
EFAULT "Bad address",
|
||||||
|
ENOTBLK "Block device required",
|
||||||
|
EBUSY "Mount device busy",
|
||||||
|
EEXIST "File exists",
|
||||||
|
EXDEV "Cross-device link",
|
||||||
|
ENODEV "No such device",
|
||||||
|
ENOTDIR "Not a directory",
|
||||||
|
EISDIR "Is a directory",
|
||||||
|
EINVAL "Invalid argument",
|
||||||
|
ENFILE "File table overflow",
|
||||||
|
EMFILE "Too many open files",
|
||||||
|
ENOTTY "Not a typewriter",
|
||||||
|
ETXTBSY "Text file busy",
|
||||||
|
EFBUG "File too large",
|
||||||
|
ENOSPC "No space left on device",
|
||||||
|
ESPIPE "Illegal seek",
|
||||||
|
EROFS "Read-only file system",
|
||||||
|
EMLINK "Too many links",
|
||||||
|
EPIPE "Broken pipe",
|
||||||
|
EDOM "Math argument",
|
||||||
|
ERANGE "Result too large"
|
||||||
|
.TE
|
||||||
|
everything else causes strerror() to return "unknown error"
|
||||||
|
.IP -
|
||||||
|
The local time zone is per default MET (GMT + 1:00:00). This can be
|
||||||
|
changed through the TZ environment variable, or by some changes in the
|
||||||
|
sources.
|
||||||
|
.IP -
|
||||||
|
The clock() function returns the number of ticks since process
|
||||||
|
startup.
|
||||||
|
.SH
|
||||||
|
References
|
||||||
|
.IP [1]
|
||||||
|
ANS X3.159-1989
|
||||||
|
.I
|
||||||
|
American National Standard for Information Systems -
|
||||||
|
Programming Language C
|
||||||
|
.R
|
||||||
949
doc/basic.doc
Normal file
949
doc/basic.doc
Normal file
@ -0,0 +1,949 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.TL
|
||||||
|
.de Sy
|
||||||
|
.LP
|
||||||
|
.IP \fBsyntax\fR 10
|
||||||
|
..
|
||||||
|
.de PU
|
||||||
|
.IP \fBpurpose\fR 10
|
||||||
|
..
|
||||||
|
.de RM
|
||||||
|
.IP \fBremarks\fR 10
|
||||||
|
..
|
||||||
|
The ABC compiler
|
||||||
|
.AU
|
||||||
|
Martin L. Kersten
|
||||||
|
Gert-Jan Akkerman
|
||||||
|
Marcel Worring
|
||||||
|
Edo Westerhuis
|
||||||
|
Frans Kunst
|
||||||
|
Ronnie Lachniet
|
||||||
|
.AI
|
||||||
|
Department of Mathematics and Computer Science.
|
||||||
|
.br
|
||||||
|
Free University
|
||||||
|
.br
|
||||||
|
Amsterdam
|
||||||
|
.AB
|
||||||
|
This manual describes the
|
||||||
|
programming language BASIC and its compiler
|
||||||
|
included in the Amsterdam Compiler Kit.
|
||||||
|
.AE
|
||||||
|
.SH
|
||||||
|
INTRODUCTION.
|
||||||
|
.LP
|
||||||
|
The BASIC-EM compiler is an extensive implementation of the
|
||||||
|
programming language BASIC.
|
||||||
|
The language structure and semantics are modelled after the
|
||||||
|
BASIC interpreter/compiler of Microsoft (tr), a short comparison
|
||||||
|
is provided in appendix A.
|
||||||
|
.LP
|
||||||
|
The compiler generates code for a virtual machine, the EM machine
|
||||||
|
[[ACM, etc]].
|
||||||
|
Using EM as an intermediate machine results in a highly portable
|
||||||
|
compiler and BASIC code.
|
||||||
|
.br
|
||||||
|
The drawback of EM is that it does not directly reflect one particular
|
||||||
|
hardware design, which means that many of the low level operations available
|
||||||
|
within BASIC are ill-defined or even inapplicable.
|
||||||
|
To mention a few, the peek and poke instructions are likely
|
||||||
|
to be behave errorneous, while line printer and tapedeck
|
||||||
|
primitives are unknown.
|
||||||
|
.LP
|
||||||
|
This manual is divided into three chapters.
|
||||||
|
.br
|
||||||
|
Chapter 1 discusses the general language syntax and semantics.
|
||||||
|
.br
|
||||||
|
Chapter 2 describes the statements available in BASIC-EM.
|
||||||
|
.br
|
||||||
|
Chapter 3 describes the predefined functions, ordered alphabetically.
|
||||||
|
.LP
|
||||||
|
Appendix A discusses the differences with Microsoft BASIC.
|
||||||
|
.br
|
||||||
|
Appendix B describes all reserved symbols.
|
||||||
|
.LP
|
||||||
|
.LP
|
||||||
|
.SH
|
||||||
|
SYNTAX NOTATION
|
||||||
|
.LP
|
||||||
|
The conventions for syntax presentation are as follows:
|
||||||
|
.IP CAPS 10
|
||||||
|
Items are reserved words, must be input as shown.
|
||||||
|
.IP <> 10
|
||||||
|
Items in lowercase letters enclosed in angular brackets
|
||||||
|
are to be supplied by the user.
|
||||||
|
.IP [] 10
|
||||||
|
Items are optional.
|
||||||
|
.IP \.\.\. 10
|
||||||
|
Items may be repeated any number of times
|
||||||
|
.IP {} 10
|
||||||
|
A choice between two or more alternatives. At least one of the entries
|
||||||
|
must be chosen.
|
||||||
|
.IP | 10
|
||||||
|
Vertical bars separate the choices within braces.
|
||||||
|
.LP
|
||||||
|
All punctuation must be included where shown.
|
||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
GENERAL INFORMATION
|
||||||
|
.LP
|
||||||
|
The BASIC-EM compiler is designed for a UNIX based environment.
|
||||||
|
It accepts a text file with a BASIC program (suffix .b) and generates
|
||||||
|
an executable file, called a.out.
|
||||||
|
.NH 2
|
||||||
|
LINE FORMAT
|
||||||
|
.LP
|
||||||
|
A BASIC program consists of a series of lines, starting with a
|
||||||
|
positive line number in the range 0 to 32767.
|
||||||
|
A line may consists of more than one physical line on a terminal, but
|
||||||
|
is limited to 1024 characters.
|
||||||
|
Multiple BASIC statements may be placed on a single line, provided
|
||||||
|
they are separated by a colon (:).
|
||||||
|
.NH 2
|
||||||
|
CONSTANTS
|
||||||
|
.LP
|
||||||
|
The BASIC compiler character set is comprised of alphabetic
|
||||||
|
characters, numeric characters, and special characters shown below.
|
||||||
|
.DS
|
||||||
|
= + - * / ^ ( ) % # $ \\ _
|
||||||
|
! [ ] , . ; : & ' ? > < \\ (blanc)
|
||||||
|
.DE
|
||||||
|
.LP
|
||||||
|
BASIC uses two different types of constants during processing:
|
||||||
|
numeric and string constants.
|
||||||
|
.br
|
||||||
|
A string constant is a sequence of characters taken from the ASCII
|
||||||
|
character set enclosed by double quotation marks.
|
||||||
|
.br
|
||||||
|
Numeric constants are positive or negative numbers, grouped into
|
||||||
|
five different classes.
|
||||||
|
.IP "a) integer constants" 25
|
||||||
|
.br
|
||||||
|
Whole numbers in the range of -32768 and 32767. Integer constants do
|
||||||
|
not contain decimal points.
|
||||||
|
.IP "b) fixed point constants" 25
|
||||||
|
.br
|
||||||
|
Positive or negative real numbers, i.e. numbers with a decimal point.
|
||||||
|
.IP "c) floating point constants" 25
|
||||||
|
.br
|
||||||
|
Real numbers in scientific notation. A floating point constant
|
||||||
|
consists of an optional signed integer or fixed point number
|
||||||
|
followed by the letter E (or D) and an optional signed integer
|
||||||
|
(the exponent).
|
||||||
|
The allowable range of floating point constants is 10^-38 to 10^+38.
|
||||||
|
.IP "d) Hex constants" 25
|
||||||
|
.br
|
||||||
|
Hexadecimal numbers, denoted by the prefix &H.
|
||||||
|
.IP "e) Octal constants" 25
|
||||||
|
.br
|
||||||
|
Octal numbers, denoted by the prefix &O.
|
||||||
|
.NH 2
|
||||||
|
VARIABLES
|
||||||
|
.LP
|
||||||
|
Variables are names used to represent values in a BASIC program.
|
||||||
|
A variable is assigned a value by assigment specified in the program.
|
||||||
|
Before a variable is assigned its value is assumed to be zero.
|
||||||
|
.br
|
||||||
|
Variable names are composed of letters, digits or the decimal point,
|
||||||
|
starting with a letter. Up to 40 characters are significant.
|
||||||
|
A variable name can be followed by any of the following type
|
||||||
|
declaration characters:
|
||||||
|
.IP % 5
|
||||||
|
Defines an integer variable
|
||||||
|
.IP ! 5
|
||||||
|
Defines a single precision variable (see below)
|
||||||
|
.IP # 5
|
||||||
|
Defines a double precision variable
|
||||||
|
.IP $ 5
|
||||||
|
Defines a string variable.
|
||||||
|
.LP
|
||||||
|
Beside single valued variables, values may be grouped into tables or arrays.
|
||||||
|
Each element in an array is referenced by the array name and an index,
|
||||||
|
such a variable is called a subscripted variable.
|
||||||
|
An array has as many subscripts as there are dimensions in the array,
|
||||||
|
the maximum of which is 11.
|
||||||
|
.br
|
||||||
|
If a variable starts with FN it is assumed to be a call to a user defined
|
||||||
|
function.
|
||||||
|
.br
|
||||||
|
A variable name may not be a reserved word nor the name
|
||||||
|
of a predefined function.
|
||||||
|
A list of all reserved identifiers is included as Appendix B.
|
||||||
|
.LP
|
||||||
|
NOTES:
|
||||||
|
.br
|
||||||
|
Two variables with the same name but different type is
|
||||||
|
considered illegal.
|
||||||
|
.br
|
||||||
|
The type of a variable without typedeclaration-character is set,
|
||||||
|
at it's first occurence in the program,
|
||||||
|
to the defaulttype which is (in this implementation) double precision.
|
||||||
|
.br
|
||||||
|
Multi-dimensional array's must be declared before use (see
|
||||||
|
DIM-statement ).
|
||||||
|
.br
|
||||||
|
BASIC-EM differs from Microsoft BASIC in supporting floats in one precision
|
||||||
|
only (due to EM), eg doubles and floats have the same precision.
|
||||||
|
.NH 2
|
||||||
|
EXPRESSIONS
|
||||||
|
.LP
|
||||||
|
When necessary the compiler will convert a numeric value from
|
||||||
|
one type to another.
|
||||||
|
A value is always converted to the precision of the variable it is assigned
|
||||||
|
to.
|
||||||
|
When a floating point value is converted to an integer the fractional
|
||||||
|
portion is rounded.
|
||||||
|
In an expression all values are converted to the same degree of precision,
|
||||||
|
i.e. that of the most precise operand.
|
||||||
|
.br
|
||||||
|
Division by zero results in the message "Division by zero".
|
||||||
|
If overflow (or underflow) occurs, the "Overflow (underflow)" message is
|
||||||
|
displayed and execution is terminated (contrary to Microsoft).
|
||||||
|
.SH
|
||||||
|
Arithmetic
|
||||||
|
.LP
|
||||||
|
The arithmetic operators in order of precedence,a re:
|
||||||
|
.DS L
|
||||||
|
^ Exponentiation
|
||||||
|
- Negation
|
||||||
|
*,/,\\\\\\\\,MOD Multiplication, Division, Remainder
|
||||||
|
+,- Addition, Substraction
|
||||||
|
.DE
|
||||||
|
The operator \\\\ denotes integer division, its operands are rounded to
|
||||||
|
integers before the operator is applied.
|
||||||
|
Modulus arithmetic is denoted by the operator MOD, which yields the
|
||||||
|
integer value that is the remainder of an integer division.
|
||||||
|
.br
|
||||||
|
The order in which operators are performed can be changed with parentheses.
|
||||||
|
.SH
|
||||||
|
Relational
|
||||||
|
.LP
|
||||||
|
The relational operators in order of precedence, are:
|
||||||
|
.DS
|
||||||
|
= Equality
|
||||||
|
<> Inequality
|
||||||
|
< Less than
|
||||||
|
> Greater than
|
||||||
|
<= Less than or equal to
|
||||||
|
>= Greater than or equal to
|
||||||
|
.DE
|
||||||
|
The relational operators are used to compare two values and returns
|
||||||
|
either "true" (-1) or "false" (0) (See IF statement).
|
||||||
|
The precedence of the relational operators is lower
|
||||||
|
then the arithmetic operators.
|
||||||
|
.SH
|
||||||
|
Logical
|
||||||
|
.LP
|
||||||
|
The logical operators performs tests on multiple relations, bit manipulations,
|
||||||
|
or boolean operations.
|
||||||
|
The logical operators returns a bitwise result ("true" or "false").
|
||||||
|
In an expression, logical operators are performed after the relational and
|
||||||
|
arithmetic operators.
|
||||||
|
The logical operators work by converting their operands to signed
|
||||||
|
two-complement integers in the range -32768 to 32767.
|
||||||
|
.DS
|
||||||
|
NOT Bitwise negation
|
||||||
|
AND Bitwise and
|
||||||
|
OR Bitwise or
|
||||||
|
XOR Bitwise exclusive or
|
||||||
|
EQV Bitwise equivalence
|
||||||
|
IMP Bitwise implies
|
||||||
|
.DE
|
||||||
|
.SH
|
||||||
|
Functional
|
||||||
|
.LP
|
||||||
|
A function is used in an expression to call a system or user defined
|
||||||
|
function.
|
||||||
|
A list of predefined functions is presented in chapter 3.
|
||||||
|
.SH
|
||||||
|
String operations
|
||||||
|
.LP
|
||||||
|
Strings can be concatenated by using +. Strings can be compared with
|
||||||
|
the relational operators. String comparison is performed in lexicographic
|
||||||
|
order.
|
||||||
|
.NH 2
|
||||||
|
ERROR MESSAGES
|
||||||
|
.LP
|
||||||
|
The occurence of an error results in termination of the program
|
||||||
|
unless an ON....ERROR statement has been encountered.
|
||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
B-EM STATEMENTS
|
||||||
|
.LP
|
||||||
|
This chapter describes the statements available within the BASIC-EM
|
||||||
|
compiler. Each description is formatted as follows:
|
||||||
|
.Sy
|
||||||
|
Shows the correct syntax for the statement. See introduction of
|
||||||
|
syntax notation above.
|
||||||
|
.PU
|
||||||
|
Describes the purpose and details of the instructions.
|
||||||
|
.RM
|
||||||
|
Describes special cases, deviation from Microsoft BASIC etc.
|
||||||
|
.LP
|
||||||
|
.NH 2
|
||||||
|
CALL
|
||||||
|
.Sy
|
||||||
|
CALL <variable name>[(<argument list>)]
|
||||||
|
.PU
|
||||||
|
The CALL statement provides the means to execute procedures
|
||||||
|
and functions written in another language included in the
|
||||||
|
Amsterdam Compiler Kit.
|
||||||
|
The argument list consist of (subscripted) variables.
|
||||||
|
The BASIC compiler pushes the address of the arguments on the stack in order
|
||||||
|
of encounter.
|
||||||
|
.RM
|
||||||
|
Not yet available.
|
||||||
|
.NH 2
|
||||||
|
CLOSE
|
||||||
|
.Sy
|
||||||
|
CLOSE [[#]<file number>[,[#]<file number...>]]
|
||||||
|
.PU
|
||||||
|
To terminate I/O on a disk file.
|
||||||
|
<file number> is the number associated with the file
|
||||||
|
when it was OPENed (See OPEN-statement). Ommission of parameters results in closing
|
||||||
|
all files.
|
||||||
|
.sp
|
||||||
|
The END statement and STOP statement always issue a CLOSE of
|
||||||
|
all files.
|
||||||
|
.NH 2
|
||||||
|
DATA
|
||||||
|
.Sy
|
||||||
|
DATA <list of constants>
|
||||||
|
.PU
|
||||||
|
DATA statements are used to construct a data bank of values that are
|
||||||
|
accessed by the program's READ statement.
|
||||||
|
DATA statements are non-executable,
|
||||||
|
the data items are assembled in a data file by the BASIC compiler.
|
||||||
|
This file can be replaced, provided the layout remains
|
||||||
|
the same (otherwise the RESTORE won't function properly).
|
||||||
|
.sp
|
||||||
|
The list of data items consists of numeric and string constants
|
||||||
|
as discussed in section 1.
|
||||||
|
Moreover, string constants starting with a letter and not
|
||||||
|
containing blancs, newlines, commas, colon need not be enclosed with
|
||||||
|
the string quotes.
|
||||||
|
.sp
|
||||||
|
DATA statements can be reread using the RESTORE statement.
|
||||||
|
.NH 2
|
||||||
|
DEF FN
|
||||||
|
.Sy
|
||||||
|
DEF FN<name> [(<parameterlist>)]=<expression>
|
||||||
|
.PU
|
||||||
|
To define and name a function that is written by the user.
|
||||||
|
<name> must be an identifier and should be preceded by FN,
|
||||||
|
which is considered integral part of the function name.
|
||||||
|
<expression> defines the expression to be evaluated upon function call.
|
||||||
|
.sp
|
||||||
|
The parameter list is comprised of a comma separated
|
||||||
|
list of variable names, used within the function definition,
|
||||||
|
that are to replaced by values upon function call.
|
||||||
|
The variable names defined in the parameterlist, called formal
|
||||||
|
parameters, do not affect the definition and use of variables
|
||||||
|
defined with the same name in the rest of the BASIC program.
|
||||||
|
.sp
|
||||||
|
A type declaration character may be suffixed to the function name to
|
||||||
|
designate the data type of the function result.
|
||||||
|
.NH 2
|
||||||
|
DEFINT/SNG/DBL/STR
|
||||||
|
.Sy
|
||||||
|
DEF<type> <range of letters>
|
||||||
|
.PU
|
||||||
|
Any undefined variable starting with the letter included in the range of
|
||||||
|
letters is declared of type <type> unless a type declaration character
|
||||||
|
is appended.
|
||||||
|
The range of letters is a comma separated list of characters and
|
||||||
|
character ranges (<letter>-<letter>).
|
||||||
|
.NH 2
|
||||||
|
DIM
|
||||||
|
.Sy
|
||||||
|
DIM <list of subscripted variable>
|
||||||
|
.PU
|
||||||
|
The DIM statement allocates storage for subscripted variables.
|
||||||
|
If an undefined subscripted variable is used
|
||||||
|
the maximum value of the array subscript is assumed to be 10.
|
||||||
|
A subscript out of range is signalled by the program (when ACK works)
|
||||||
|
The minimum subscript value is 0, unless the OPTION BASE statement has been
|
||||||
|
encountered.
|
||||||
|
.sp
|
||||||
|
All variables in a subscripted variable are initially zero.
|
||||||
|
.sp
|
||||||
|
BUGS. Multi-dimensional arrays MUST be defined. Subscript out of range is
|
||||||
|
left unnotified.
|
||||||
|
.NH 2
|
||||||
|
END
|
||||||
|
.Sy
|
||||||
|
END
|
||||||
|
.PU
|
||||||
|
END terminates a BASIC program and returns to the UNIX shell.
|
||||||
|
An END statement at the end of the BASIC program is optional.
|
||||||
|
.NH 2
|
||||||
|
ERR and ERL
|
||||||
|
.Sy
|
||||||
|
<identifier name>= ERR
|
||||||
|
.br
|
||||||
|
<identifier name>= ERL
|
||||||
|
.PU
|
||||||
|
Whenever an error occurs the variable ERR contains the
|
||||||
|
error number and ERL the BASIC line where the error occurred.
|
||||||
|
The variables are usually used in error handling routines
|
||||||
|
provided by the user.
|
||||||
|
.NH 2
|
||||||
|
ERROR
|
||||||
|
.Sy
|
||||||
|
ERROR <integer expression>
|
||||||
|
.PU
|
||||||
|
To simulate the occurrence of a BASIC error.
|
||||||
|
To define a private error code a value must be used that is not already in
|
||||||
|
use by the BASIC runtime system.
|
||||||
|
The list of error messages currently in use can be found in appendix B.
|
||||||
|
.NH 2
|
||||||
|
FIELD
|
||||||
|
.PU
|
||||||
|
To be implemented.
|
||||||
|
.NH 2
|
||||||
|
FOR...NEXT
|
||||||
|
.Sy
|
||||||
|
FOR <variable>= <low>TO<high>[STEP<size>]
|
||||||
|
.br
|
||||||
|
......
|
||||||
|
.br
|
||||||
|
NEXT [<variable>][,<variable>...]
|
||||||
|
.PU
|
||||||
|
The FOR statements allows a series of statements to be performed
|
||||||
|
repeatedly. <variable> is used as a counter. During the first
|
||||||
|
execution pass it is assigned the value <low>,
|
||||||
|
an arithmetic expression. After each pass the counter
|
||||||
|
is incremented (decremented) with the step size <size>, an expression.
|
||||||
|
Ommission of the step size is intepreted as an increment of 1.
|
||||||
|
.br
|
||||||
|
Execution of the program lines specified between the FOR and the NEXT
|
||||||
|
statement is terminated as soon as <low> is greater (less) than <high>
|
||||||
|
.sp
|
||||||
|
The NEXT statement is labeled with the name(s) of the counter to be
|
||||||
|
incremented.
|
||||||
|
.sp
|
||||||
|
The variables mentioned in the NEXT statement may be ommitted, in which case
|
||||||
|
the variable of increment the counter of the most recent FOR statement.
|
||||||
|
If a NEXT statement is encountered before its corresponding FOR statement,
|
||||||
|
the error message "NEXT without FOR" is generated.
|
||||||
|
.NH 2
|
||||||
|
GET
|
||||||
|
.Sy
|
||||||
|
GET [#]<file number>[, <record number>]
|
||||||
|
.PU
|
||||||
|
To be implemented.
|
||||||
|
.NH 2
|
||||||
|
GOSUB...RETURN
|
||||||
|
.Sy
|
||||||
|
GOSUB <line number>
|
||||||
|
...
|
||||||
|
.br
|
||||||
|
RETURN
|
||||||
|
.PU
|
||||||
|
The GOSUB statement branches to the first statement of a subroutine.
|
||||||
|
The RETURN statement cause a branch back to the statement following the
|
||||||
|
most recent GOSUB statement.
|
||||||
|
A subroutine may contain more than one RETURN statement.
|
||||||
|
.sp
|
||||||
|
Subroutines may be called recursively.
|
||||||
|
Nesting of subroutine calls is limited, upon exceeding the maximum depth
|
||||||
|
the error message "XXXXX" is displayed.
|
||||||
|
.NH 2
|
||||||
|
GOTO
|
||||||
|
.Sy
|
||||||
|
GOTO <line number>
|
||||||
|
.PU
|
||||||
|
To branch unconditionally to a specified line in the program.
|
||||||
|
If <line number> does not exists, the compilation error message
|
||||||
|
"Line not defined" is displayed.
|
||||||
|
.RM
|
||||||
|
Microsoft BASIC continues at the first line
|
||||||
|
equal or greater then the line specified.
|
||||||
|
.NH 2
|
||||||
|
IF...THEN
|
||||||
|
.Sy
|
||||||
|
.br
|
||||||
|
IF <expression> THEN {<statements>|<line number>}
|
||||||
|
[ELSE {<statements>|<line number>}]
|
||||||
|
.br
|
||||||
|
.Sy
|
||||||
|
IF <expression> GOTO <line number>
|
||||||
|
[ELSE {<statements>|<line number>}]
|
||||||
|
.PU
|
||||||
|
The IF statement is used
|
||||||
|
to make a decision regarding the program flow based on the
|
||||||
|
result of the expressions.
|
||||||
|
If the expression is not zero, the THEN or GOTO clause is
|
||||||
|
executed. If the result of <expression> is zero, the THEN or
|
||||||
|
GOTO clause is ignored and the ELSE clause, if present is
|
||||||
|
executed.
|
||||||
|
.br
|
||||||
|
IF..THEN..ELSE statements may be nested.
|
||||||
|
Nesting is limited by the length of the line.
|
||||||
|
The ELSE clause matches with the closests unmatched THEN.
|
||||||
|
.sp
|
||||||
|
When using IF to test equality for a value that is the
|
||||||
|
result of a floating point expression, remember that the
|
||||||
|
internal representation of the value may not be exact.
|
||||||
|
Therefore, the test should be against a range to
|
||||||
|
handle the relative error.
|
||||||
|
.RM
|
||||||
|
Microsoft BASIC allows a comma before THEN.
|
||||||
|
.NH 2
|
||||||
|
INPUT
|
||||||
|
.Sy
|
||||||
|
INPUT [;][<"prompt string">;]<list of variables>
|
||||||
|
.PU
|
||||||
|
An INPUT statement can be used to obtain values from the user at the
|
||||||
|
terminal.
|
||||||
|
When an INPUT statement is encountered a question mark is printed
|
||||||
|
to indicate the program is awaiting data.
|
||||||
|
IF <"prompt string"> is included, the string is printed before the
|
||||||
|
the question mark. The question mark is suppressed when the prompt
|
||||||
|
string is followed by a comma, rather then a semicolon.
|
||||||
|
.sp
|
||||||
|
For each variable in the variable a list a value should be supplied.
|
||||||
|
Data items presented should be separated by a comma.
|
||||||
|
.sp
|
||||||
|
The type of the variable in the variable list must aggree with the
|
||||||
|
type of the data item entered. Responding with too few or too many
|
||||||
|
data items causes the message "?Redo". No assignment of input values
|
||||||
|
is made until an acceptable response is given.
|
||||||
|
.RM
|
||||||
|
The option to disgard the carriage return with the semicolon after the
|
||||||
|
input symbol is not yet implemented.
|
||||||
|
.NH 2
|
||||||
|
INPUT [#]
|
||||||
|
.Sy
|
||||||
|
INPUT #<file number>,<list of variables>
|
||||||
|
.PU
|
||||||
|
The purpose of the INPUT# statement is to read data items from a sequential
|
||||||
|
file and assign them to program variables.
|
||||||
|
<file number> is the number used to open the file for input.
|
||||||
|
The variables mentioned are (subscripted) variables.
|
||||||
|
The type of the data items read should aggree with the type of the variables.
|
||||||
|
A type mismatch results in the error message "XXXXX".
|
||||||
|
.sp
|
||||||
|
The data items on the sequential file are separated by commas and newlines.
|
||||||
|
In scanning the file, leading spaces, new lines, tabs, and
|
||||||
|
carriage returns are ignored. The first character encountered
|
||||||
|
is assumed to be the state of a new item.
|
||||||
|
String items need not be enclosed with double quotes, provided
|
||||||
|
it does not contain spaces, tabs, newlines and commas,
|
||||||
|
.RM
|
||||||
|
Microsoft BASIC won't assign values until the end of input statement.
|
||||||
|
This means that the user has to supply all the information.
|
||||||
|
.NH 2
|
||||||
|
LET
|
||||||
|
.Sy
|
||||||
|
[LET]<variable>=<expression>
|
||||||
|
.PU
|
||||||
|
To assign the value of an expression to a (subscribted) variable.
|
||||||
|
The type convertions as dictated in chapter 1 apply.
|
||||||
|
.NH 2
|
||||||
|
LINE INPUT
|
||||||
|
.Sy
|
||||||
|
LINE INPUT [;][<"prompt string">;]<string variable>
|
||||||
|
.PU
|
||||||
|
An entire line of input is assigned to the string variable.
|
||||||
|
See INPUT for the meaning of the <"prompt string"> option.
|
||||||
|
.NH 2
|
||||||
|
LINE INPUT [#]
|
||||||
|
.Sy
|
||||||
|
LINE INPUT #<file number>,<string variable>
|
||||||
|
.PU
|
||||||
|
Read an entire line of text from a sequential file <file number>
|
||||||
|
and assign it to a string variable.
|
||||||
|
.NH 2
|
||||||
|
LSET and RSET
|
||||||
|
.PU
|
||||||
|
To be implemented
|
||||||
|
.NH 2
|
||||||
|
MID$
|
||||||
|
.Sy
|
||||||
|
MID$(<string expr1>,n[,m])=<string expr2>
|
||||||
|
.PU
|
||||||
|
To replace a portion of a string with another string value.
|
||||||
|
The characters of <string expr2> replaces characters in <string expr1>
|
||||||
|
starting at position n. If m is present, at most m characters are copied,
|
||||||
|
otherwise all characters are copied.
|
||||||
|
However, the string obtained never exceeds the length of string expr1.
|
||||||
|
.NH 2
|
||||||
|
ON ERROR GOTO
|
||||||
|
.Sy
|
||||||
|
ON ERROR GOTO <line number>
|
||||||
|
.PU
|
||||||
|
To enable error handling within the BASIC program.
|
||||||
|
An error may result from arithmetic errors, disk problems, interrupts, or
|
||||||
|
as a result of the ERROR statement.
|
||||||
|
After printing an error message the program is continued at the
|
||||||
|
statements associated with <line number>.
|
||||||
|
.sp
|
||||||
|
Error handling is disabled using ON ERROR GOTO 0.
|
||||||
|
Subsequent errors result in an error message and program termination.
|
||||||
|
.NH 2
|
||||||
|
ON...GOSUB and ON ...GOTO
|
||||||
|
.Sy
|
||||||
|
ON <expression> GOSUB <list of line numbers>
|
||||||
|
.br
|
||||||
|
ON <expression> GOTO <list of line numbers>
|
||||||
|
.PU
|
||||||
|
To branch to one of several specified line numbers or subroutines, based
|
||||||
|
on the result of the <expression>. The list of line numbers are considered
|
||||||
|
the first, second, etc alternative. Branching to the first occurs when
|
||||||
|
the expression evaluates to one, to the second alternative on two, etc.
|
||||||
|
If the value of the expression is zero or greater than the number of alternatives, processing continues at the first statement following the ON..GOTO
|
||||||
|
(ON GOSUB) statement.
|
||||||
|
.sp
|
||||||
|
When the expression results in a negative number the
|
||||||
|
an "Illegal function call" error occurs.
|
||||||
|
.sp
|
||||||
|
BUG If the value of the expression is zero or greater than the number of
|
||||||
|
alternatives, processing does NOT continue at the first statement
|
||||||
|
following the ON..GOTO (ON GOSUB) statement.
|
||||||
|
.NH 2
|
||||||
|
OPEN
|
||||||
|
.Sy
|
||||||
|
OPEN {"i" | "o" | "r" } , [#]<file number> , <file-name>
|
||||||
|
.PU
|
||||||
|
To open <file-name> (filename should be quoted) for input/reading or output.
|
||||||
|
If file is not opened for output it has to be existent, otherwise an
|
||||||
|
"file not found" error will occur.
|
||||||
|
.NH 2
|
||||||
|
OPTION BASE
|
||||||
|
.Sy
|
||||||
|
OPTION BASE n
|
||||||
|
.PU
|
||||||
|
To declare the lower bound of subsequent array subscripts as either
|
||||||
|
0 or 1. The default lower bound is zero.
|
||||||
|
.NH 2
|
||||||
|
POKE
|
||||||
|
.Sy
|
||||||
|
POKE <expr1>,<expr2>
|
||||||
|
.PU
|
||||||
|
To poke around in memory. The use of this statement is not recommended,
|
||||||
|
because it requires full understanding of both
|
||||||
|
the implementation of the Amsterdam
|
||||||
|
Compiler Kit and the hardware characteristics.
|
||||||
|
.NH 2
|
||||||
|
PRINT
|
||||||
|
.Sy
|
||||||
|
PRINT <list of variables and/or constants>
|
||||||
|
.PU
|
||||||
|
To print constants or the contents of variables on the terminal-device.
|
||||||
|
If the variables or constants are seperated by comma's the values will
|
||||||
|
be printed seperated by tabs.
|
||||||
|
If the variables or constants are seperated by semi-colon's the values
|
||||||
|
will be printed without spaces in between.
|
||||||
|
The new-line generated at the end of the print-statement can be suppressed by
|
||||||
|
a semi-colon at the end of list of variables or constants.
|
||||||
|
.NH 2
|
||||||
|
PRINT USING
|
||||||
|
.PU
|
||||||
|
To be implemented
|
||||||
|
.NH 2
|
||||||
|
PUT
|
||||||
|
.PU
|
||||||
|
To be implemented
|
||||||
|
.NH 2
|
||||||
|
RANDOMIZE
|
||||||
|
.Sy
|
||||||
|
RANDOMIZE [<expression>]
|
||||||
|
.PU
|
||||||
|
To reset the random seed. When the expression is ommitted, the system
|
||||||
|
will ask for a value between -32768 and 32767.
|
||||||
|
The random number generator returns the same sequence of values provided
|
||||||
|
the same seed is used.
|
||||||
|
.NH 2
|
||||||
|
READ
|
||||||
|
.Sy
|
||||||
|
READ <list of variables>
|
||||||
|
.PU
|
||||||
|
To read values from the DATA statements and assign them to variables.
|
||||||
|
The type of the variables should match to the type of the items being read,
|
||||||
|
otherwise a "Syntax error" occurs. If all data is read the message "Out of
|
||||||
|
data" will be displayed.
|
||||||
|
.NH 2
|
||||||
|
REM
|
||||||
|
.Sy
|
||||||
|
REM <remark>
|
||||||
|
.PU
|
||||||
|
To include explantory information in a program.
|
||||||
|
The REM statements are not executed.
|
||||||
|
A single quote has the same effect as : REM, which
|
||||||
|
allows for the inclusion of comment at the end of the line.
|
||||||
|
.RM
|
||||||
|
Microsoft BASIC does not allow REM statements as part of
|
||||||
|
DATA lines.
|
||||||
|
.NH 2
|
||||||
|
RESTORE
|
||||||
|
.Sy
|
||||||
|
RESTORE [<line number>]
|
||||||
|
.PU
|
||||||
|
To allow DATA statements to be re-read from a specific line.
|
||||||
|
After a RESTORE statement is executed, the next READ accesses
|
||||||
|
the first item of the DATA statements.
|
||||||
|
If <line number> is specified, the next READ accesses the first
|
||||||
|
item in the specified line.
|
||||||
|
.sp
|
||||||
|
Note that data statements result in a sequential datafile generated
|
||||||
|
by the compiler, being read by the read statements.
|
||||||
|
This data file may be replaced using the operating system functions
|
||||||
|
with a modified version, provided the same layout of items
|
||||||
|
(same number of lines and items per line) is used.
|
||||||
|
.NH 2
|
||||||
|
STOP
|
||||||
|
.Sy
|
||||||
|
STOP
|
||||||
|
.PU
|
||||||
|
To terminate the execution of a program and return to the operating system
|
||||||
|
command interpreter. A STOP statement results in the message "Break in line
|
||||||
|
???"
|
||||||
|
.NH 2
|
||||||
|
SWAP
|
||||||
|
.Sy
|
||||||
|
SWAP <variable>,<variable>
|
||||||
|
.PU
|
||||||
|
To exchange the values of two variables.
|
||||||
|
.sp
|
||||||
|
BUG. Strings cannot be swapped !
|
||||||
|
.NH 2
|
||||||
|
TRON/TROFF
|
||||||
|
.Sy
|
||||||
|
TRON
|
||||||
|
.Sy
|
||||||
|
TROFF
|
||||||
|
.PU
|
||||||
|
As an aid in debugging the TRON statement results in a program
|
||||||
|
listing each line being interpreted. TROFF disables generation of
|
||||||
|
this code.
|
||||||
|
.NH 2
|
||||||
|
WHILE...WEND
|
||||||
|
.Sy
|
||||||
|
WHILE <expression>
|
||||||
|
.....
|
||||||
|
WEND
|
||||||
|
.PU
|
||||||
|
To execute a series of BASIC statements as long as a conditional expression
|
||||||
|
is true. WHILE...WEND loops may be nested.
|
||||||
|
.NH 2
|
||||||
|
WRITE
|
||||||
|
.Sy
|
||||||
|
WRITE [<list of expressions>]
|
||||||
|
.PU
|
||||||
|
To write data at the terminal in DATA statement layout conventions.
|
||||||
|
The expressions should be separated by commas.
|
||||||
|
.NH 2
|
||||||
|
WRITE #
|
||||||
|
.Sy
|
||||||
|
WRITE #<file number> ,<list of expressions>
|
||||||
|
.PU
|
||||||
|
To write a sequential data file, being opened with the "O" mode.
|
||||||
|
The values are being writting using the DATA statements layout conventions.
|
||||||
|
.bp
|
||||||
|
.NH
|
||||||
|
FUNCTIONS
|
||||||
|
.LP
|
||||||
|
.IP ABS(X) 25
|
||||||
|
Returns the absolute value of expression X
|
||||||
|
.IP ASC(X$) 25
|
||||||
|
Returns the numeric value of the first character of the string.
|
||||||
|
If X$ is not initialized an "Illegal function call" error
|
||||||
|
is returned.
|
||||||
|
.IP ATN(X) 25
|
||||||
|
Returns the arctangent of X in radians. Result is in the range
|
||||||
|
of -pi/2 to pi/2.
|
||||||
|
.IP CDBL(X) 25
|
||||||
|
Converts X to a double precision number.
|
||||||
|
.IP CHR$(X) 25
|
||||||
|
Converts the integer value X to its ASCII character.
|
||||||
|
X must be in the range of 0 to 257.
|
||||||
|
It is used for cursor addressing and generating bel signals.
|
||||||
|
.IP CINT(X) 25
|
||||||
|
Converts X to an integer by rounding the fractional portion.
|
||||||
|
If X is not in the range -32768 to 32767 an "Overflow"
|
||||||
|
error occurs.
|
||||||
|
.IP COS(X) 25
|
||||||
|
Returns the cosine of X in radians.
|
||||||
|
.IP CSNG(X) 25
|
||||||
|
Converts X to a single precision number.
|
||||||
|
.IP CVI(<2-bytes>) 25
|
||||||
|
Convert two byte string value to integer number.
|
||||||
|
.IP CVS(<4-bytes>) 25
|
||||||
|
Convert four byte string value to single precision number.
|
||||||
|
.IP CVD(<8-bytes>) 25
|
||||||
|
Convert eight byte string value to double precision number.
|
||||||
|
.IP EOF[(<file-number>)] 25
|
||||||
|
Returns -1 (true) if the end of a sequential file has been reached.
|
||||||
|
.IP EXP(X) 25
|
||||||
|
Returns e(base of natural logarithm) to the power of X.
|
||||||
|
X should be less then 10000.0.
|
||||||
|
.IP FIX(X) 25
|
||||||
|
Returns the truncated integer part of X. FIX(X) is
|
||||||
|
equivalent to SGN(X)*INT(ABS(X)).
|
||||||
|
The major difference between FIX and INT is that FIX does not
|
||||||
|
return the next lower number for negative X.
|
||||||
|
.IP HEX$(X) 25
|
||||||
|
Returns the string which represents the hexadecimal value of
|
||||||
|
the decimal argument. X is rounded to an integer using CINT
|
||||||
|
before HEX$ is evaluated.
|
||||||
|
.IP INT(X) 25
|
||||||
|
Returns the largest integer <= X.
|
||||||
|
.IP INP$(X[,[#]Y]) 25
|
||||||
|
Returns the string of X characters read from the terminal or
|
||||||
|
the designated file.
|
||||||
|
.IP LEN(X$) 25
|
||||||
|
Returns the number of characters in the string X$.
|
||||||
|
Non printable and blancs are counted too.
|
||||||
|
.IP LOC(<file\ number>) 25
|
||||||
|
For sequential files LOC returns
|
||||||
|
position of the read/write head, counted in number of bytes.
|
||||||
|
For random files the function returns the record number just
|
||||||
|
read or written from a GET or PUT statement.
|
||||||
|
If nothing was read or written 0 is returned.
|
||||||
|
.IP LOG(X) 25
|
||||||
|
Returns the natural logarithm of X. X must be greater than zero.
|
||||||
|
.IP MID$(X,I,[J]) 25
|
||||||
|
Returns first J characters from string X starting at position I in X.
|
||||||
|
If J is omitted all characters starting of from position I in X are returned.
|
||||||
|
.IP MKI$(X) 25
|
||||||
|
Converts an integer expression to a two-byte string.
|
||||||
|
.IP MKS$(X) 25
|
||||||
|
Converts a single precision expression to a four-byte string.
|
||||||
|
.IP MKD$(X) 25
|
||||||
|
Converts a double precision expression to a eight-byte string.
|
||||||
|
.IP OCT$(X) 25
|
||||||
|
Returns the string which represents the octal value of the decimal
|
||||||
|
argument. X is rounded to an integer using CINT before OCTS is evaluated.
|
||||||
|
.IP PEEK(I) 25
|
||||||
|
Returns the byte read from the indicated memory. (Of limited use
|
||||||
|
in the context of ACK)
|
||||||
|
.IP POS(I) 25
|
||||||
|
Returns the current cursor position. To be implemented.
|
||||||
|
.IP RIGHT$(X$,I)
|
||||||
|
Returns the right most I characters of string X$.
|
||||||
|
If I=0 then the empty string is returned.
|
||||||
|
.IP RND(X) 25
|
||||||
|
Returns a random number between 0 and 1. X is a dummy argument.
|
||||||
|
.IP SGN(X) 25
|
||||||
|
If X>0 , SGN(X) returns 1.
|
||||||
|
.br
|
||||||
|
if X=0, SGN(X) returns 0.
|
||||||
|
.br
|
||||||
|
if X<0, SGN(X) returns -1.
|
||||||
|
.IP SIN(X) 25
|
||||||
|
Returns the sine of X in radians.
|
||||||
|
.IP SPACE$(X) 25
|
||||||
|
Returns a string of spaces length X. The expression
|
||||||
|
X is rounded to an integer using CINT.
|
||||||
|
.IP STR$(X)
|
||||||
|
Returns the string representation value of X.
|
||||||
|
.IP STRING$(I,J) 25
|
||||||
|
Returns thes string of length Iwhose characters all
|
||||||
|
have ASCII code J. (or first character when J is a string)
|
||||||
|
.IP TAB(I) 25
|
||||||
|
Spaces to position I on the terminal. If the current
|
||||||
|
print position is already beyond space I,TAB
|
||||||
|
goes to that position on the next line.
|
||||||
|
Space 1 is leftmost position, and the rightmost position
|
||||||
|
is width minus 1. To be used within PRINT statements only.
|
||||||
|
.IP TAN(X) 25
|
||||||
|
Returns the tangent of X in radians. If TAN overflows
|
||||||
|
the "Overflow" message is displayed.
|
||||||
|
.IP VAL(X$) 25
|
||||||
|
Returns the numerical value of string X$.
|
||||||
|
The VAL function strips leading blanks and tabs from the
|
||||||
|
argument string.
|
||||||
|
.bp
|
||||||
|
.SH
|
||||||
|
APPENDIX A DIFFERENCES WITH MICROSOFT BASIC
|
||||||
|
.LP
|
||||||
|
The following list of Microsoft commands and statements are
|
||||||
|
not recognized by the compiler.
|
||||||
|
.DS
|
||||||
|
SPC
|
||||||
|
USR
|
||||||
|
VARPTR
|
||||||
|
AUTO
|
||||||
|
CHAIN
|
||||||
|
CLEAR
|
||||||
|
CLOAD
|
||||||
|
COMMON
|
||||||
|
CONT
|
||||||
|
CSAVE
|
||||||
|
DELETE
|
||||||
|
EDIT
|
||||||
|
ERASE
|
||||||
|
FRE
|
||||||
|
KILL
|
||||||
|
LIST
|
||||||
|
LLIST
|
||||||
|
LOAD
|
||||||
|
LPRINT
|
||||||
|
MERGE
|
||||||
|
NAME
|
||||||
|
NEW
|
||||||
|
NULL
|
||||||
|
RENUM
|
||||||
|
RESUME
|
||||||
|
RUN
|
||||||
|
SAVE
|
||||||
|
WAIT
|
||||||
|
WIDTH LPRINT
|
||||||
|
.DE
|
||||||
|
Some statements are in the current implementation not available,
|
||||||
|
but will be soon. These include:
|
||||||
|
.DS
|
||||||
|
CALL
|
||||||
|
DEFUSR
|
||||||
|
FIELD
|
||||||
|
GET
|
||||||
|
INKEY
|
||||||
|
INPUT$
|
||||||
|
INSTR$
|
||||||
|
LEFT$
|
||||||
|
LSET
|
||||||
|
RSET
|
||||||
|
PUT
|
||||||
|
.DE
|
||||||
|
.bp
|
||||||
|
.SH
|
||||||
|
APPENDIX B RESERVED WORDS IN BASIC-EM
|
||||||
|
.LP
|
||||||
|
The following list of words/symbols/names/identifiers are reserved, which
|
||||||
|
means that they can not be used for variable-names.
|
||||||
|
.DS
|
||||||
|
ABS AND ASC AS
|
||||||
|
ATN AUTO BASE CALL
|
||||||
|
CDBL CHAIN CHR CINT
|
||||||
|
CLEAR CLOAD CLOSE COMMON
|
||||||
|
CONT COS CSNG CSAVE
|
||||||
|
CVI CVS CVD DATA
|
||||||
|
DEFINT DEFSNG DEFDBL DEFSTR
|
||||||
|
DEF DELETE DIM EDIT
|
||||||
|
ELSE END EOF ERASE
|
||||||
|
ERROR ERR ERL ELSE
|
||||||
|
EQV EXP FIELD FIX
|
||||||
|
FOR FRE GET GOSUB
|
||||||
|
GOTO HEX IF IMP
|
||||||
|
INKEY INPUT INP INSTR
|
||||||
|
INT KILL LEFT LEN
|
||||||
|
LET LINE LIST LLIST
|
||||||
|
LOAD LOC LOG LPOS
|
||||||
|
LPRINT LSET MERGE MID
|
||||||
|
MKI MKS MKD MOD
|
||||||
|
NAME NEW NEXT NOT
|
||||||
|
NULL ON OCT OPEN
|
||||||
|
OPTION OR OUT PEEK
|
||||||
|
POKE PRINT POS PUT
|
||||||
|
RANDOMIZE READ REM RENUM
|
||||||
|
REN RESTORE RESUME RETURN
|
||||||
|
RIGHT RND RUN SAVE
|
||||||
|
STEP SGN SIN SPACE
|
||||||
|
SPC SQR STOP STRING
|
||||||
|
STR SWAP TAB TAN
|
||||||
|
THEN TO TRON TROFF
|
||||||
|
USING USR VAL VARPTR
|
||||||
|
WAIT WHILE WEND WIDTH
|
||||||
|
WRITE XOR
|
||||||
|
.DE
|
||||||
3
doc/ceg/.distr
Normal file
3
doc/ceg/.distr
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
proto.make
|
||||||
|
ceg.ref
|
||||||
|
ceg.tr
|
||||||
42
doc/ceg/ceg.ref
Normal file
42
doc/ceg/ceg.ref
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
%T A Practical Toolkit For Making Compilers
|
||||||
|
%A A.S. Tanenbaum
|
||||||
|
%A H. v. Staveren
|
||||||
|
%A E.G. Keizer
|
||||||
|
%A J.W. Stevenson
|
||||||
|
%J Communications of the ACM
|
||||||
|
%V 26
|
||||||
|
%N 9
|
||||||
|
%D September 1983
|
||||||
|
|
||||||
|
%T Description of a Machine Architecture for Use with Block Structured Languages
|
||||||
|
%A A.S. Tanenbuum
|
||||||
|
%A H. v. Staveren
|
||||||
|
%A E.G. Keizer
|
||||||
|
%A J.W. Stevenson
|
||||||
|
%R IR-81
|
||||||
|
%I Dept. Mathematics and Computer Science, Vrije Universiteit
|
||||||
|
%C Amsterdam
|
||||||
|
%D August 1983
|
||||||
|
|
||||||
|
%T EM_CODE(3ACK)
|
||||||
|
%A ACK Documentation
|
||||||
|
%I Dept. Mathematics and Computer Science, Vrije Universiteit
|
||||||
|
%C Amsterdam
|
||||||
|
|
||||||
|
%T ACK.OUT(5ACK)
|
||||||
|
%A ACK Documentation
|
||||||
|
%I Dept. Mathematics and Computer Science, Vrije Universiteit
|
||||||
|
%C Amsterdam
|
||||||
|
%K aout
|
||||||
|
|
||||||
|
%T PRINT(3ACK)
|
||||||
|
%A ACK Documentation
|
||||||
|
%I Dept. Mathematics and Computer Science, Vrije Universiteit
|
||||||
|
%C Amsterdam
|
||||||
|
|
||||||
|
%T The C Programming Language
|
||||||
|
%A B.W. Kernighan
|
||||||
|
%A D.M. Ritchie
|
||||||
|
%I Prentice-Hall Inc.
|
||||||
|
%C Englewood Cliffs, New Jersey
|
||||||
|
%D 1978
|
||||||
1587
doc/ceg/ceg.tr
Normal file
1587
doc/ceg/ceg.tr
Normal file
File diff suppressed because it is too large
Load Diff
12
doc/ceg/proto.make
Normal file
12
doc/ceg/proto.make
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
# $Id$
|
||||||
|
|
||||||
|
#PARAMS do not remove this line!
|
||||||
|
|
||||||
|
SRC_DIR = $(SRC_HOME)/doc/ceg
|
||||||
|
|
||||||
|
PIC=pic
|
||||||
|
TBL=tbl
|
||||||
|
REFER=refer
|
||||||
|
|
||||||
|
$(TARGET_HOME)/doc/ceg.doc: $(SRC_DIR)/ceg.tr $(SRC_DIR)/ceg.ref
|
||||||
|
$(PIC) $(SRC_DIR)/ceg.tr | $(REFER) -e -p $(SRC_DIR)/ceg.ref | $(TBL) > $@
|
||||||
1864
doc/cg.doc
Normal file
1864
doc/cg.doc
Normal file
File diff suppressed because it is too large
Load Diff
629
doc/crefman.doc
Normal file
629
doc/crefman.doc
Normal file
@ -0,0 +1,629 @@
|
|||||||
|
\." $Id$
|
||||||
|
.\" eqn crefman.doc | troff -ms
|
||||||
|
.EQ
|
||||||
|
delim $$
|
||||||
|
.EN
|
||||||
|
.RP
|
||||||
|
.TL
|
||||||
|
ACK/CEM Compiler
|
||||||
|
.br
|
||||||
|
Reference Manual
|
||||||
|
.AU
|
||||||
|
Erik H. Baalbergen
|
||||||
|
.AI
|
||||||
|
Department of Mathematics and Computer Science
|
||||||
|
Vrije Universiteit
|
||||||
|
Amsterdam
|
||||||
|
The Netherlands
|
||||||
|
.AB no
|
||||||
|
.AE
|
||||||
|
.NH
|
||||||
|
C Language
|
||||||
|
.PP
|
||||||
|
This section discusses the extensions to and deviations from the C language,
|
||||||
|
as described in [1].
|
||||||
|
The issues are numbered according to the reference manual.
|
||||||
|
.SH
|
||||||
|
2.2 Identifiers
|
||||||
|
.PP
|
||||||
|
Upper and lower case letters are different.
|
||||||
|
The number of significant letters
|
||||||
|
is 32 by default, but may be set to another value using the \fB\-M\fP option.
|
||||||
|
The identifier length should be set according to the rest of the compilation
|
||||||
|
programs.
|
||||||
|
.SH
|
||||||
|
2.3 Keywords
|
||||||
|
.SH
|
||||||
|
\f(CWasm\fP
|
||||||
|
.PP
|
||||||
|
The keyword \f(CWasm\fP
|
||||||
|
is recognized.
|
||||||
|
However, the statement
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
asm(string);
|
||||||
|
.ft R
|
||||||
|
.DE
|
||||||
|
is skipped, while a warning is given.
|
||||||
|
.SH
|
||||||
|
\f(CWenum\fP
|
||||||
|
.PP
|
||||||
|
The \f(CWenum\fP keyword is recognized and interpreted.
|
||||||
|
.SH
|
||||||
|
\f(CWentry\fP, \f(CWfortran\fP
|
||||||
|
.PP
|
||||||
|
The words \f(CWentry\fP and \f(CWfortran\fP
|
||||||
|
are reserved under the restricted option.
|
||||||
|
The words are not interpreted by the compiler.
|
||||||
|
.SH
|
||||||
|
2.4.1 Integer Constants
|
||||||
|
.PP
|
||||||
|
The type of an integer constant is the first of the corresponding list
|
||||||
|
in which its value can be represented. Decimal: \f(CWint, long, unsigned long\fP;
|
||||||
|
octal or hexadecimal: \f(CWint, unsigned, long, unsigned long\fP; suffixed by
|
||||||
|
the letter L or l: \f(CWlong, unsigned long\fP.
|
||||||
|
.SH
|
||||||
|
2.4.3 Character Constants
|
||||||
|
.PP
|
||||||
|
A character constant is a sequence of 1 up to \f(CWsizeof(int)\fP characters
|
||||||
|
enclosed in single quotes.
|
||||||
|
The value of a character constant '$c sub 1 c sub 2 ... c sub n$'
|
||||||
|
is $d sub n + M \(mu d sub {n - 1} + ... + M sup {n - 1} \(mu d sub 2 + M sup n \(mu d sub 1$,
|
||||||
|
where M is 1 + maximum unsigned number representable in an \f(CWunsigned char\fP,
|
||||||
|
and $d sub i$ is the signed value (ASCII)
|
||||||
|
of character $c sub i$.
|
||||||
|
.SH
|
||||||
|
2.4.4 Floating Constants
|
||||||
|
.PP
|
||||||
|
The compiler does not support compile-time floating point arithmetic.
|
||||||
|
.SH
|
||||||
|
2.6 Hardware characteristics
|
||||||
|
.PP
|
||||||
|
The compiler is capable of producing EM code for machines with the following
|
||||||
|
properties
|
||||||
|
.IP \(bu
|
||||||
|
a \f(CWchar\fP is 8 bits
|
||||||
|
.IP \(bu
|
||||||
|
the size of \f(CWint\fP is equal to the word size
|
||||||
|
.IP \(bu
|
||||||
|
the size of \f(CWshort\fP may not exceed the size of \f(CWint\fP
|
||||||
|
.IP \(bu
|
||||||
|
the size of \f(CWint\fP may not exceed the size of \f(CWlong\fP
|
||||||
|
.IP \(bu
|
||||||
|
the size of pointers is equal to the size of either \f(CWshort\fP, \f(CWint\fP
|
||||||
|
or \f(CWlong\fP
|
||||||
|
.LP
|
||||||
|
.SH
|
||||||
|
4 What's in a name?
|
||||||
|
.SH
|
||||||
|
\f(CWchar\fP
|
||||||
|
.PP
|
||||||
|
Objects of type \f(CWchar\fP are taken to be signed.
|
||||||
|
The combination \f(CWunsigned char\fP is legal.
|
||||||
|
.SH
|
||||||
|
\f(CWunsigned\fP
|
||||||
|
.PP
|
||||||
|
The type combinations \f(CWunsigned char\fP, \f(CWunsigned short\fP and
|
||||||
|
\f(CWunsigned long\fP are supported.
|
||||||
|
.SH
|
||||||
|
\f(CWenum\fP
|
||||||
|
.PP
|
||||||
|
The data type \f(CWenum\fP is implemented as described
|
||||||
|
in \fIRecent Changes to C\fP (see appendix A).
|
||||||
|
.I Cem
|
||||||
|
treats enumeration variables as if they were \f(CWint\fP.
|
||||||
|
.SH
|
||||||
|
\f(CWvoid\fP
|
||||||
|
.PP
|
||||||
|
Type \f(CWvoid\fP is implemented.
|
||||||
|
The type specifies an empty set of values, which takes no storage space.
|
||||||
|
.SH
|
||||||
|
\fRFundamental types\fP
|
||||||
|
.PP
|
||||||
|
The names of the fundamental types can be redefined by the user, using
|
||||||
|
\f(CWtypedef\fP.
|
||||||
|
.SH
|
||||||
|
7 Expressions
|
||||||
|
.PP
|
||||||
|
The order of evaluation of expressions depends on the complexity of the
|
||||||
|
subexpressions.
|
||||||
|
In case of commutative operations, the most complex subexpression is
|
||||||
|
evaluated first.
|
||||||
|
Parameter lists are evaluated from right to left.
|
||||||
|
.SH
|
||||||
|
7.2 Unary operators
|
||||||
|
.PP
|
||||||
|
The type of a \f(CWsizeof\fP expression is \f(CWunsigned int\fP.
|
||||||
|
.SH
|
||||||
|
7.13 Conditional operator
|
||||||
|
.PP
|
||||||
|
Both the second and the third expression in a conditional expression may
|
||||||
|
include assignment operators.
|
||||||
|
They may be structs or unions.
|
||||||
|
.SH
|
||||||
|
7.14 Assignment operators
|
||||||
|
.PP
|
||||||
|
Structures may be assigned, passed as arguments to functions, and returned
|
||||||
|
by functions.
|
||||||
|
The types of operands taking part must be the same.
|
||||||
|
.SH
|
||||||
|
8.2 Type specifiers
|
||||||
|
.PP
|
||||||
|
The combinations \f(CWunsigned char\fP, \f(CWunsigned short\fP
|
||||||
|
and \f(CWunsigned long\fP are implemented.
|
||||||
|
.SH
|
||||||
|
8.5 Structure and union declarations
|
||||||
|
.PP
|
||||||
|
Fields of any integral type, either signed or unsigned,
|
||||||
|
are supported, as long as the type fits in a word on the target machine.
|
||||||
|
.PP
|
||||||
|
Fields are left adjusted by default; the first field is put into the left
|
||||||
|
part of a word, the next one on the right side of the first one, etc.
|
||||||
|
The \f(CW-Vr\fP option in the call of the compiler
|
||||||
|
causes fields to be right adjusted within a machine word.
|
||||||
|
.PP
|
||||||
|
The tags of structs and unions occupy a different name space from that of
|
||||||
|
variables and that of member names.
|
||||||
|
.SH
|
||||||
|
9.7 Switch statement
|
||||||
|
.PP
|
||||||
|
The type of \fIexpression\fP in
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
\f(CWswitch (\fP\fIexpression\fP\f(CW)\fP \fIstatement\fP
|
||||||
|
.ft
|
||||||
|
.DE
|
||||||
|
must be integral.
|
||||||
|
A warning is given under the restricted option if the type is \f(CWlong\fP.
|
||||||
|
.SH
|
||||||
|
10 External definitions
|
||||||
|
.PP
|
||||||
|
See [4] for a discussion on this complicated issue.
|
||||||
|
.SH
|
||||||
|
10.1 External function definitions
|
||||||
|
.PP
|
||||||
|
Structures may be passed as arguments to functions, and returned
|
||||||
|
by functions.
|
||||||
|
.SH
|
||||||
|
11.1 Lexical scope
|
||||||
|
.PP
|
||||||
|
Typedef names may be redeclared like any other variable name; the ice mentioned
|
||||||
|
in \(sc11.1 is walked correctly.
|
||||||
|
.SH
|
||||||
|
12 Compiler control lines
|
||||||
|
.PP
|
||||||
|
Lines which do not occur within comment, and with \f(CW#\fP as first
|
||||||
|
character, are interpreted as compiler control line.
|
||||||
|
There may be an arbitrary number of spaces, tabs and comments (collectively
|
||||||
|
referred as \fIwhite space\fP) following the \f(CW#\fP.
|
||||||
|
Comments may contain newline characters.
|
||||||
|
Control lines with only white space between the \f(CW#\fP and the line separator
|
||||||
|
are skipped.
|
||||||
|
.PP
|
||||||
|
The #\f(CWinclude\fP, #\f(CWifdef\fP, #\f(CWifndef\fP, #\f(CWundef\fP, #\f(CWelse\fP and
|
||||||
|
#\f(CWendif\fP control lines and line directives consist of a fixed number of
|
||||||
|
arguments.
|
||||||
|
The list of arguments may be followed an arbitrary sequence of characters,
|
||||||
|
in which comment is interpreted as such.
|
||||||
|
(I.e., the text between \f(CW/*\fP and \f(CW*/\fP is skipped, regardless of
|
||||||
|
newlines; note that commented-out lines beginning with \f(CW#\fP are not
|
||||||
|
considered to be control lines.)
|
||||||
|
.SH
|
||||||
|
12.1 Token replacement
|
||||||
|
.PP
|
||||||
|
The replacement text of macros is taken to be a string of characters, in which
|
||||||
|
an identifier may stand for a formal parameter, and in which comment is
|
||||||
|
interpreted as such.
|
||||||
|
Comments and newline characters, preceeded by a backslash, in the replacement
|
||||||
|
text are replaced by a space character.
|
||||||
|
.PP
|
||||||
|
The actual parameters of a macro are considered tokens and are
|
||||||
|
balanced with regard to \f(CW()\fP, \f(CW{}\fP and \f(CW[]\fP.
|
||||||
|
This prevents the use of macros like
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
CTL([)
|
||||||
|
.ft
|
||||||
|
.DE
|
||||||
|
.PP
|
||||||
|
Formal parameters of a macro must have unique names within the formal-parameter
|
||||||
|
list of that macro.
|
||||||
|
.PP
|
||||||
|
A message is given at the definition of a macro if the macro has
|
||||||
|
already been #\f(CWdefined\fP, while the number of formal parameters differ or
|
||||||
|
the replacement texts are not equal (apart from leading and trailing
|
||||||
|
white space).
|
||||||
|
.PP
|
||||||
|
Recursive use of macros is detected by the compiler.
|
||||||
|
.PP
|
||||||
|
Standard #\f(CWdefined\fP macros are
|
||||||
|
.DS
|
||||||
|
\f(CW__FILE__\fP name of current input file as string constant
|
||||||
|
\f(CW__DATE__\fP curent date as string constant; e.g. \f(CW"Tue Wed 2 14:45:23 1986"\fP
|
||||||
|
\f(CW__LINE__\fP current line number as an integer
|
||||||
|
.DE
|
||||||
|
.PP
|
||||||
|
No message is given if \fIidentifier\fP is not known in
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
#undef \fIidentifier\fP
|
||||||
|
.ft
|
||||||
|
.DE
|
||||||
|
.SH
|
||||||
|
12.2 File inclusion
|
||||||
|
.PP
|
||||||
|
A newline character is appended to each file which is included.
|
||||||
|
.SH
|
||||||
|
12.3 Conditional compilation
|
||||||
|
.PP
|
||||||
|
The #\f(CWif\fP, #\f(CWifdef\fP and #\f(CWifndef\fP control lines may be followed
|
||||||
|
by an arbitrary number of
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
#elif \fIconstant-expression\fP
|
||||||
|
.ft
|
||||||
|
.DE
|
||||||
|
control lines, before the corresponding #\f(CWelse\fP or #\f(CWendif\fP
|
||||||
|
is encountered.
|
||||||
|
The construct
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
#elif \fIconstant-expression\fP
|
||||||
|
some text
|
||||||
|
#endif /* corresponding to #elif */
|
||||||
|
.ft
|
||||||
|
.DE
|
||||||
|
is equivalent to
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
#else
|
||||||
|
#if \fIconstant-expression\fP
|
||||||
|
some text
|
||||||
|
#endif /* corresponding to #if */
|
||||||
|
#endif /* corresponding to #else */
|
||||||
|
.ft
|
||||||
|
.DE
|
||||||
|
.PP
|
||||||
|
The \fIconstant-expression\fP in #\f(CWif\fP and #\f(CWelif\fP control lines
|
||||||
|
may contain the construction
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
defined(\fIidentifier\fP)
|
||||||
|
.ft
|
||||||
|
.DE
|
||||||
|
which is replaced by \f(CW1\fP, if \fIidentifier\fP has been #\f(CWdefined\fP,
|
||||||
|
and by \f(CW0\fP, if not.
|
||||||
|
.PP
|
||||||
|
Comments in skipped lines are interpreted as such.
|
||||||
|
.SH
|
||||||
|
12.4 Line control
|
||||||
|
.PP
|
||||||
|
Line directives may occur in the following forms:
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
#line \fIconstant\fP
|
||||||
|
#line \fIconstant\fP "\fIfilename\fP"
|
||||||
|
#\fIconstant\fP
|
||||||
|
#\fIconstant\fP "\fIfilename\fP"
|
||||||
|
.ft
|
||||||
|
.DE
|
||||||
|
Note that \fIfilename\fP is enclosed in double quotes.
|
||||||
|
.SH
|
||||||
|
14.2 Functions
|
||||||
|
.PP
|
||||||
|
If a pointer to a function is called, the function the pointer points to
|
||||||
|
is called instead.
|
||||||
|
.SH
|
||||||
|
15 Constant expressions
|
||||||
|
.PP
|
||||||
|
The compiler distinguishes the following types of integral constant expressions
|
||||||
|
.IP \(bu
|
||||||
|
field-width specifier
|
||||||
|
.IP \(bu
|
||||||
|
case-entry specifier
|
||||||
|
.IP \(bu
|
||||||
|
array-size specifier
|
||||||
|
.IP \(bu
|
||||||
|
global variable initialization value
|
||||||
|
.IP \(bu
|
||||||
|
enum-value specifier
|
||||||
|
.IP \(bu
|
||||||
|
truth value in \f(CW#if\fP control line
|
||||||
|
.LP
|
||||||
|
.PP
|
||||||
|
Constant integral expressions are compile-time evaluated while an effort
|
||||||
|
is made to report overflow.
|
||||||
|
Constant floating expressions are not compile-time evaluated.
|
||||||
|
.NH
|
||||||
|
Compiler flags
|
||||||
|
.IP \fB\-C\fR
|
||||||
|
Run the preprocessor stand-alone while maintaining the comments.
|
||||||
|
Line directives are produced whenever needed.
|
||||||
|
.IP \fB\-D\fP\fIname\fP=\fIstring-of-characters\fP
|
||||||
|
.br
|
||||||
|
Define \fIname\fR as macro with \fIstring-of-characters\fR as
|
||||||
|
replacement text.
|
||||||
|
.IP \fB\-D\fP\fIname\fP
|
||||||
|
.br
|
||||||
|
Equal to \fB\-D\fP\fIname\fP\fB=1\fP.
|
||||||
|
.IP \fB\-E\fP
|
||||||
|
Run the preprocessor stand alone, i.e.,
|
||||||
|
list the sequence of input tokens and delete any comments.
|
||||||
|
Line directives are produced whenever needed.
|
||||||
|
.IP \fB\-I\fIpath\fR
|
||||||
|
.br
|
||||||
|
Prepend \fIpath\fR to the list of include directories.
|
||||||
|
To put the directories "include", "sys/h" and "util/h" into the
|
||||||
|
include directory list in that order, the user has to specify
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
-Iinclude -Isys/h -Iutil/h
|
||||||
|
.ft R
|
||||||
|
.DE
|
||||||
|
An empty \fIpath\fP causes the standard include
|
||||||
|
directory (usually \f(CW/usr/include\fP) to be forgotten.
|
||||||
|
.IP \fB\-M\fP\fIn\fP
|
||||||
|
.br
|
||||||
|
Set maximum significant identifier length to \fIn\fP.
|
||||||
|
.IP \fB\-n\fP
|
||||||
|
Suppress EM register messages.
|
||||||
|
The user-declared variables are not stored into registers on the target
|
||||||
|
machine.
|
||||||
|
.IP \fB\-p\fP
|
||||||
|
Generate the EM \fBfil\fP and \fBlin\fP instructions in order to enable
|
||||||
|
an interpreter to keep track of the current location in the source code.
|
||||||
|
.IP \fB\-P\fP
|
||||||
|
Equivalent with \fB\-E\fP, but without line directives.
|
||||||
|
.IP \fB\-R\fP
|
||||||
|
Interpret the input as restricted C (according to the language as
|
||||||
|
described in [1]).
|
||||||
|
.IP \fB\-T\fP\fIpath\fP
|
||||||
|
.br
|
||||||
|
Create temporary files, if necessary, in directory \fIpath\fP.
|
||||||
|
.IP \fB\-U\fP\fIname\fP
|
||||||
|
.br
|
||||||
|
Get rid of the compiler-predefined macro \fIname\fP, i.e.,
|
||||||
|
consider
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
#undef \fIname\fP
|
||||||
|
.ft R
|
||||||
|
.DE
|
||||||
|
to appear in the beginning of the file.
|
||||||
|
.IP \fB\-V\fIcm\fR.\fIn\fR,\ \fB\-V\fIcm\fR.\fIncm\fR.\fIn\fR\ ...
|
||||||
|
.br
|
||||||
|
Set the size and alignment requirements.
|
||||||
|
The letter \fIc\fR indicates the simple type, which is one of
|
||||||
|
\fBs\fR(short), \fBi\fR(int), \fBl\fR(long), \fBf\fR(float), \fBd\fR(double)
|
||||||
|
or \fBp\fR(pointer).
|
||||||
|
If \fIc\fR is \fBS\fP or \fBU\fP, then \fIn\fP is taken to be the initial
|
||||||
|
alignment of structs or unions, respectively.
|
||||||
|
The effective alignment of a struct or union is the least common multiple
|
||||||
|
of the initial struct/union alignment and the alignments of its members.
|
||||||
|
The \fIm\fR parameter can be used to specify the length of the type (in bytes)
|
||||||
|
and the \fIn\fR parameter for the alignment of that type.
|
||||||
|
Absence of \fIm\fR or \fIn\fR causes the default value to be retained.
|
||||||
|
To specify that the bitfields should be right adjusted instead of the
|
||||||
|
default left adjustment, specify \fBr\fR as \fIc\fR parameter.
|
||||||
|
.IP \fB\-w\fR
|
||||||
|
Suppress warning messages
|
||||||
|
.IP \fB\-\-\fIcharacter\fR
|
||||||
|
.br
|
||||||
|
Set debug-flag \fIcharacter\fP.
|
||||||
|
This enables some special features offered by a debug and develop version of
|
||||||
|
the compiler.
|
||||||
|
Some particular flags may be recognized, others may have surprising effects.
|
||||||
|
.RS
|
||||||
|
.IP \fBd\fP
|
||||||
|
Generate a dependency graph, reflecting the calling structure of functions.
|
||||||
|
Lines of the form
|
||||||
|
.DS
|
||||||
|
.ft CW
|
||||||
|
DFA: \fIcalling-function\fP: \fIcalled-function\fP
|
||||||
|
.ft
|
||||||
|
.DE
|
||||||
|
are generated whenever a function call is encountered.
|
||||||
|
.IP \fBf\fP
|
||||||
|
Dump whole identifier table, including macros and reserved words.
|
||||||
|
.IP \fBh\fP
|
||||||
|
Supply hash-table statistics.
|
||||||
|
.IP \fBi\fP
|
||||||
|
Print names of included files.
|
||||||
|
.IP \fBm\fP
|
||||||
|
Supply statistics concerning the memory allocation.
|
||||||
|
.IP \fBt\fP
|
||||||
|
Dump table of identifiers.
|
||||||
|
.IP \fBu\fP
|
||||||
|
Generate extra statistics concerning the predefined types and identifiers.
|
||||||
|
Works in combination with \fBf\fP or \fBt\fP.
|
||||||
|
.IP \fBx\fP
|
||||||
|
Print expression trees in human-readable format.
|
||||||
|
.RE
|
||||||
|
.LP
|
||||||
|
.SH
|
||||||
|
References
|
||||||
|
.IP [1]
|
||||||
|
Brian W. Kernighan, Dennis M. Ritchie,
|
||||||
|
.I
|
||||||
|
The C Programming Language
|
||||||
|
.R
|
||||||
|
.IP [2]
|
||||||
|
L. Rosler,
|
||||||
|
.I
|
||||||
|
Draft Proposed Standard - Programming Language C,
|
||||||
|
.R
|
||||||
|
ANSI X3J11 Language Subcommittee
|
||||||
|
.IP [3]
|
||||||
|
Erik H. Baalbergen, Dick Grune, Maarten Waage,
|
||||||
|
.I
|
||||||
|
The CEM Compiler,
|
||||||
|
.R
|
||||||
|
Informatica Manual IM-4, Dept. of Mathematics and Computer Science, Vrije
|
||||||
|
Universiteit, Amsterdam, The Netherlands
|
||||||
|
.IP [4]
|
||||||
|
Erik H. Baalbergen,
|
||||||
|
.I
|
||||||
|
Modeling global declarations in C,
|
||||||
|
.R
|
||||||
|
internal paper
|
||||||
|
.LP
|
||||||
|
.bp
|
||||||
|
.SH
|
||||||
|
Appendix A - Enumeration Type
|
||||||
|
.PP
|
||||||
|
The syntax is
|
||||||
|
.sp
|
||||||
|
.RS
|
||||||
|
.I enum-specifier :
|
||||||
|
.RS
|
||||||
|
\&\f(CWenum\fP { \fIenum-list\fP }
|
||||||
|
.br
|
||||||
|
\&\f(CWenum\fP \fIidentifier\fP { \fIenum-list\fP }
|
||||||
|
.br
|
||||||
|
\&\f(CWenum\fP \fIidentifier\fP
|
||||||
|
.RE
|
||||||
|
.sp
|
||||||
|
\&\fIenum-list\fP :
|
||||||
|
.RS
|
||||||
|
\&\fIenumerator\fP
|
||||||
|
.br
|
||||||
|
\&\fIenum-list\fP , \fIenumerator\fP
|
||||||
|
.RE
|
||||||
|
.sp
|
||||||
|
\&\fIenumerator\fP :
|
||||||
|
.RS
|
||||||
|
\&\fIidentifier\fP
|
||||||
|
.br
|
||||||
|
\&\fIidentifier\fP = \fIconstant-expression\fP
|
||||||
|
.RE
|
||||||
|
.sp
|
||||||
|
.RE
|
||||||
|
The identifier has the same role as the structure tag in a struct specification.
|
||||||
|
It names a particular enumeration type.
|
||||||
|
.PP
|
||||||
|
The identifiers in the enum-list are declared as constants, and may appear
|
||||||
|
whenever constants are required.
|
||||||
|
If no enumerators with
|
||||||
|
.B =
|
||||||
|
appear, then the values of the constants begin at 0 and increase by 1 as the
|
||||||
|
declaration is read from left to right.
|
||||||
|
An enumerator with
|
||||||
|
.B =
|
||||||
|
gives the associated identifier the value indicated; subsequent identifiers
|
||||||
|
continue the progression from the assigned value.
|
||||||
|
.PP
|
||||||
|
Enumeration tags and constants must all be distinct, and, unlike structure
|
||||||
|
tags and members, are drawn from the same set as ordinary identifiers.
|
||||||
|
.PP
|
||||||
|
Objects of a given enumeration type are regarded as having a type distinct
|
||||||
|
from objects of all other types.
|
||||||
|
.bp
|
||||||
|
.SH
|
||||||
|
Appendix B: C grammar in LL(1) form
|
||||||
|
.PP
|
||||||
|
The \fBbold-faced\fP and \fIitalicized\fP tokens represent terminal symbols.
|
||||||
|
.vs 16
|
||||||
|
.nf
|
||||||
|
\fBexternal definitions\fP
|
||||||
|
program: external-definition*
|
||||||
|
external-definition: ext-decl-specifiers [declarator [function | non-function] | '\fB;\fP'] | asm-statement
|
||||||
|
ext-decl-specifiers: decl-specifiers?
|
||||||
|
non-function: initializer? ['\fB,\fP' init-declarator]* '\fB;\fP'
|
||||||
|
function: declaration* compound-statement
|
||||||
|
.sp 1
|
||||||
|
\fBdeclarations\fP
|
||||||
|
declaration: decl-specifiers init-declarator-list? '\fB;\fP'
|
||||||
|
decl-specifiers: other-specifier+ [single-type-specifier other-specifier*]? | single-type-specifier other-specifier*
|
||||||
|
other-specifier: \fBauto\fP | \fBstatic\fP | \fBextern\fP | \fBtypedef\fP | \fBregister\fP | \fBshort\fP | \fBlong\fP | \fBunsigned\fP
|
||||||
|
type-specifier: decl-specifiers
|
||||||
|
single-type-specifier: \fItype-identifier\fP | struct-or-union-specifier | enum-specifier
|
||||||
|
init-declarator-list: init-declarator ['\fB,\fP' init-declarator]*
|
||||||
|
init-declarator: declarator initializer?
|
||||||
|
declarator: primary-declarator ['\fB(\fP' formal-list ? '\fB)\fP' | arrayer]* | '\fB*\fP' declarator
|
||||||
|
primary-declarator: identifier | '\fB(\fP' declarator '\fB)\fP'
|
||||||
|
arrayer: '\fB[\fP' constant-expression? '\fB]\fP'
|
||||||
|
formal-list: formal ['\fB,\fP' formal]*
|
||||||
|
formal: identifier
|
||||||
|
enum-specifier: \fBenum\fP [enumerator-pack | identifier enumerator-pack?]
|
||||||
|
enumerator-pack: '\fB{\fP' enumerator ['\fB,\fP' enumerator]* '\fB,\fP'? '\fB}\fP'
|
||||||
|
enumerator: identifier ['\fB=\fP' constant-expression]?
|
||||||
|
struct-or-union-specifier: [ \fBstruct\fP | \fBunion\fP] [ struct-declaration-pack | identifier struct-declaration-pack?]
|
||||||
|
struct-declaration-pack: '\fB{\fP' struct-declaration+ '\fB}\fP'
|
||||||
|
struct-declaration: type-specifier struct-declarator-list '\fB;\fP'?
|
||||||
|
struct-declarator-list: struct-declarator ['\fB,\fP' struct-declarator]*
|
||||||
|
struct-declarator: declarator bit-expression? | bit-expression
|
||||||
|
bit-expression: '\fB:\fP' constant-expression
|
||||||
|
initializer: '\fB=\fP'? initial-value
|
||||||
|
cast: '\fB(\fP' type-specifier abstract-declarator '\fB)\fP'
|
||||||
|
abstract-declarator: primary-abstract-declarator ['\fB(\fP' '\fB)\fP' | arrayer]* | '\fB*\fP' abstract-declarator
|
||||||
|
primary-abstract-declarator: ['\fB(\fP' abstract-declarator '\fB)\fP']?
|
||||||
|
.sp 1
|
||||||
|
\fBstatements\fP
|
||||||
|
statement:
|
||||||
|
expression-statement
|
||||||
|
| label '\fB:\fP' statement
|
||||||
|
| compound-statement
|
||||||
|
| if-statement
|
||||||
|
| while-statement
|
||||||
|
| do-statement
|
||||||
|
| for-statement
|
||||||
|
| switch-statement
|
||||||
|
| case-statement
|
||||||
|
| default-statement
|
||||||
|
| break-statement
|
||||||
|
| continue-statement
|
||||||
|
| return-statement
|
||||||
|
| jump
|
||||||
|
| '\fB;\fP'
|
||||||
|
| asm-statement
|
||||||
|
;
|
||||||
|
expression-statement: expression '\fB;\fP'
|
||||||
|
label: identifier
|
||||||
|
if-statement: \fBif\fP '\fB(\fP' expression '\fB)\fP' statement [\fBelse\fP statement]?
|
||||||
|
while-statement: \fBwhile\fP '\fB(\fP' expression '\fB)\fP' statement
|
||||||
|
do-statement: \fBdo\fP statement \fBwhile\fP '\fB(\fP' expression '\fB)\fP' '\fB;\fP'
|
||||||
|
for-statement: \fBfor\fP '\fB(\fP' expression? '\fB;\fP' expression? '\fB;\fP' expression? '\fB)\fP' statement
|
||||||
|
switch-statement: \fBswitch\fP '\fB(\fP' expression '\fB)\fP' statement
|
||||||
|
case-statement: \fBcase\fP constant-expression '\fB:\fP' statement
|
||||||
|
default-statement: \fBdefault\fP '\fB:\fP' statement
|
||||||
|
break-statement: \fBbreak\fP '\fB;\fP'
|
||||||
|
continue-statement: \fBcontinue\fP '\fB;\fP'
|
||||||
|
return-statement: \fBreturn\fP expression? '\fB;\fP'
|
||||||
|
jump: \fBgoto\fP identifier '\fB;\fP'
|
||||||
|
compound-statement: '\fB{\fP' declaration* statement* '\fB}\fP'
|
||||||
|
asm-statement: \fBasm\fP '\fB(\fP' \fIstring\fP '\fB)\fP' '\fB;\fP'
|
||||||
|
.sp 1
|
||||||
|
\fBexpressions\fP
|
||||||
|
initial-value: assignment-expression | initial-value-pack
|
||||||
|
initial-value-pack: '\fB{\fP' initial-value-list '\fB}\fP'
|
||||||
|
initial-value-list: initial-value ['\fB,\fP' initial-value]* '\fB,\fP'?
|
||||||
|
primary: \fIidentifier\fP | constant | \fIstring\fP | '\fB(\fP' expression '\fB)\fP'
|
||||||
|
secundary: primary [index-pack | parameter-pack | selection]*
|
||||||
|
index-pack: '\fB[\fP' expression '\fB]\fP'
|
||||||
|
parameter-pack: '\fB(\fP' parameter-list? '\fB)\fP'
|
||||||
|
selection: ['\fB.\fP' | '\fB\->\fP'] identifier
|
||||||
|
parameter-list: assignment-expression ['\fB,\fP' assignment-expression]*
|
||||||
|
postfixed: secundary postop?
|
||||||
|
unary: cast unary | postfixed | unop unary | size-of
|
||||||
|
size-of: \fBsizeof\fP [cast | unary]
|
||||||
|
binary-expression: unary [binop binary-expression]*
|
||||||
|
conditional-expression: binary-expression ['\fB?\fP' expression '\fB:\fP' assignment-expression]?
|
||||||
|
assignment-expression: conditional-expression [asgnop assignment-expression]?
|
||||||
|
expression: assignment-expression ['\fB,\fP' assignment-expression]*
|
||||||
|
unop: '\fB*\fP' | '\fB&\fP' | '\fB\-\fP' | '\fB!\fP' | '\fB~ \fP' | '\fB++\fP' | '\fB\-\-\fP'
|
||||||
|
postop: '\fB++\fP' | '\fB\-\-\fP'
|
||||||
|
multop: '\fB*\fP' | '\fB/\fP' | '\fB%\fP'
|
||||||
|
addop: '\fB+\fP' | '\fB\-\fP'
|
||||||
|
shiftop: '\fB<<\fP' | '\fB>>\fP'
|
||||||
|
relop: '\fB<\fP' | '\fB>\fP' | '\fB<=\fP' | '\fB>=\fP'
|
||||||
|
eqop: '\fB==\fP' | '\fB!=\fP'
|
||||||
|
arithop: multop | addop | shiftop | '\fB&\fP' | '\fB^ \fP' | '\fB|\fP'
|
||||||
|
binop: arithop | relop | eqop | '\fB&&\fP' | '\fB||\fP'
|
||||||
|
asgnop: '\fB=\fP' | '\fB+\fP' '\fB=\fP' | '\fB\-\fP' '\fB=\fP' | '\fB*\fP' '\fB=\fP' | '\fB/\fP' '\fB=\fP' | '\fB%\fP' '\fB=\fP'
|
||||||
|
| '\fB<<\fP' '\fB=\fP' | '\fB>>\fP' '\fB=\fP' | '\fB&\fP' '\fB=\fP' | '\fB^ \fP' '\fB=\fP' | '\fB|\fP' '\fB=\fP'
|
||||||
|
| '\fB+=\fP' | '\fB\-=\fP' | '\fB*=\fP' | '\fB/=\fP' | '\fB%=\fP'
|
||||||
|
| '\fB<<=\fP' | '\fB>>=\fP' | '\fB&=\fP' | '\fB^=\fP' | '\fB|=\fP'
|
||||||
|
constant: \fIinteger\fP | \fIfloating\fP
|
||||||
|
constant-expression: assignment-expression
|
||||||
|
identifier: \fIidentifier\fP | \fItype-identifier\fP
|
||||||
|
.fi
|
||||||
18
doc/ego/.distr
Normal file
18
doc/ego/.distr
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
proto.make
|
||||||
|
bo
|
||||||
|
ca
|
||||||
|
cf
|
||||||
|
cj
|
||||||
|
cs
|
||||||
|
ic
|
||||||
|
il
|
||||||
|
intro
|
||||||
|
lv
|
||||||
|
ov
|
||||||
|
ra
|
||||||
|
refs.gen
|
||||||
|
refs.opt
|
||||||
|
refs.stat
|
||||||
|
sp
|
||||||
|
sr
|
||||||
|
ud
|
||||||
1
doc/ego/bo/.distr
Normal file
1
doc/ego/bo/.distr
Normal file
@ -0,0 +1 @@
|
|||||||
|
bo1
|
||||||
162
doc/ego/bo/bo1
Normal file
162
doc/ego/bo/bo1
Normal file
@ -0,0 +1,162 @@
|
|||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
Branch Optimization
|
||||||
|
.NH 2
|
||||||
|
Introduction
|
||||||
|
.PP
|
||||||
|
The Branch Optimization phase (BO) performs two related
|
||||||
|
(branch) optimizations.
|
||||||
|
.NH 3
|
||||||
|
Fusion of basic blocks
|
||||||
|
.PP
|
||||||
|
If two basic blocks B1 and B2 have the following properties:
|
||||||
|
.DS
|
||||||
|
SUCC(B1) = {B2}
|
||||||
|
PRED(B2) = {B1}
|
||||||
|
.DE
|
||||||
|
then B1 and B2 can be combined into one basic block.
|
||||||
|
If B1 ends in an unconditional jump to the beginning of B2, this
|
||||||
|
jump can be eliminated,
|
||||||
|
hence saving a little execution time and object code size.
|
||||||
|
This technique can be used to eliminate some deficiencies
|
||||||
|
introduced by the front ends (for example, the "C" front end
|
||||||
|
translates switch statements inefficiently due to its one pass nature).
|
||||||
|
.NH 3
|
||||||
|
While-loop optimization
|
||||||
|
.PP
|
||||||
|
The straightforward way to translate a while loop is to
|
||||||
|
put the test for loop termination at the beginning of the loop.
|
||||||
|
.DS
|
||||||
|
while cond loop \kyLAB1: \kxTest cond
|
||||||
|
body of the loop --->\h'|\nxu'Branch On False To LAB2
|
||||||
|
end loop\h'|\nxu'code for body of loop
|
||||||
|
\h'|\nxu'Branch To LAB1
|
||||||
|
\h'|\nyu'LAB2:
|
||||||
|
|
||||||
|
Fig. 10.1 Example of Branch Optimization
|
||||||
|
.DE
|
||||||
|
If the condition fails at the Nth iteration, the following code
|
||||||
|
gets executed (dynamically):
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l l.
|
||||||
|
N * conditional branch (which fails N-1 times)
|
||||||
|
N-1 * unconditional branch
|
||||||
|
N-1 * body of the loop
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
An alternative translation is:
|
||||||
|
.DS
|
||||||
|
Branch To LAB2
|
||||||
|
LAB1:
|
||||||
|
code for body of loop
|
||||||
|
LAB2:
|
||||||
|
Test cond
|
||||||
|
Branch On True To LAB1
|
||||||
|
.DE
|
||||||
|
This translation results in the following profile:
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l l.
|
||||||
|
N * conditional branch (which succeeds N-1 times)
|
||||||
|
1 * unconditional branch
|
||||||
|
N-1 * body of the loop
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
So the second translation will be significantly faster if N >> 2.
|
||||||
|
If N=2, execution time will be slightly increased.
|
||||||
|
On the average, the program will be speeded up.
|
||||||
|
Note that the code sizes of the two translations will be the same.
|
||||||
|
.NH 2
|
||||||
|
Implementation
|
||||||
|
.PP
|
||||||
|
The basic block fusion technique is implemented
|
||||||
|
by traversing the control flow graph of a procedure,
|
||||||
|
looking for basic blocks B with only one successor (S).
|
||||||
|
If one is found, it is checked if S has only one predecessor
|
||||||
|
(which has to be B).
|
||||||
|
If so, the two basic blocks can in principle be combined.
|
||||||
|
However, as one basic block will have to be moved,
|
||||||
|
the textual order of the basic blocks will be altered.
|
||||||
|
This reordering causes severe problems in the presence
|
||||||
|
of conditional jumps.
|
||||||
|
For example, if S ends in a conditional branch,
|
||||||
|
the basic block that comes textually next to S must stay
|
||||||
|
in that position.
|
||||||
|
So the transformation in Fig. 10.2 is illegal.
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l l l l.
|
||||||
|
LAB1: S1 LAB1: S1
|
||||||
|
BRA LAB2 S2
|
||||||
|
... --> BEQ LAB3
|
||||||
|
LAB2: S2 ...
|
||||||
|
BEQ LAB3 S3
|
||||||
|
S3
|
||||||
|
.TE
|
||||||
|
|
||||||
|
Fig. 10.2 An illegal transformation of Branch Optimization
|
||||||
|
.DE
|
||||||
|
If B is moved towards S the same problem occurs if the block before B
|
||||||
|
ends in a conditional jump.
|
||||||
|
The problem could be solved by adding one extra branch,
|
||||||
|
but this would reduce the gains of the optimization to zero.
|
||||||
|
Hence the optimization will only be done if the block that
|
||||||
|
follows S (in the textual order) is not a successor of S.
|
||||||
|
This condition assures that S does not end in a conditional branch.
|
||||||
|
The condition always holds for the code generated by the "C"
|
||||||
|
front end for a switch statement.
|
||||||
|
.PP
|
||||||
|
After the transformation has been performed,
|
||||||
|
some attributes of the basic blocks involved (such as successor and
|
||||||
|
predecessor sets and immediate dominator) must be recomputed.
|
||||||
|
.PP
|
||||||
|
The while-loop technique is applied to one loop at a time.
|
||||||
|
The list of basic blocks of the loop is traversed to find
|
||||||
|
a block B that satisfies the following conditions:
|
||||||
|
.IP 1.
|
||||||
|
the textually next block to B is not part of the loop
|
||||||
|
.IP 2.
|
||||||
|
the last instruction of B is an unconditional branch;
|
||||||
|
hence B has only one successor, say S
|
||||||
|
.IP 3.
|
||||||
|
the textually next block of B is a successor of S
|
||||||
|
.IP 4.
|
||||||
|
the last instruction of S is a conditional branch
|
||||||
|
.LP
|
||||||
|
If such a block B is found, the control flow graph is changed
|
||||||
|
as depicted in Fig. 10.3.
|
||||||
|
.DS
|
||||||
|
.ft 5
|
||||||
|
| |
|
||||||
|
| v
|
||||||
|
v |
|
||||||
|
|-----<------| ----->-----|
|
||||||
|
____|____ | |
|
||||||
|
| | | |-------| |
|
||||||
|
| S1 | | | v |
|
||||||
|
| Bcc | | | .... |
|
||||||
|
|--| | | | |
|
||||||
|
| --------- | | ----|---- |
|
||||||
|
| | | | | |
|
||||||
|
| .... ^ | | S2 | |
|
||||||
|
| | | | | |
|
||||||
|
| --------- | | | | |
|
||||||
|
v | | | ^ --------- |
|
||||||
|
| | S2 | | | | |
|
||||||
|
| | BRA | | | |-----<-----
|
||||||
|
| | | | | v
|
||||||
|
| --------- | | ____|____
|
||||||
|
| | | | | |
|
||||||
|
| ------>------ | | S1 |
|
||||||
|
| | | Bnn |
|
||||||
|
|-------| | | |
|
||||||
|
| | ----|----
|
||||||
|
v | |
|
||||||
|
|----<--|
|
||||||
|
|
|
||||||
|
v
|
||||||
|
.ft R
|
||||||
|
|
||||||
|
Fig. 10.3 Transformation of the CFG by Branch Optimization
|
||||||
|
.DE
|
||||||
1
doc/ego/ca/.distr
Normal file
1
doc/ego/ca/.distr
Normal file
@ -0,0 +1 @@
|
|||||||
|
ca1
|
||||||
65
doc/ego/ca/ca1
Normal file
65
doc/ego/ca/ca1
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
Compact assembly generation
|
||||||
|
.NH 2
|
||||||
|
Introduction
|
||||||
|
.PP
|
||||||
|
The "Compact Assembly generation phase" (CA) transforms the
|
||||||
|
intermediate code of the optimizer into EM code in
|
||||||
|
Compact Assembly Language (CAL) format.
|
||||||
|
In the intermediate code, all program entities
|
||||||
|
(such as procedures, labels, global variables)
|
||||||
|
are denoted by a unique identifying number (see 3.5).
|
||||||
|
In the CAL output of the optimizer these numbers have to
|
||||||
|
be replaced by normal identifiers (strings).
|
||||||
|
The original identifiers of the input program are used whenever possible.
|
||||||
|
Recall that the IC phase generates two files that can be
|
||||||
|
used to map unique identifying numbers to procedure names and
|
||||||
|
global variable names.
|
||||||
|
For instruction labels CA always generates new names.
|
||||||
|
The reasons for doing so are:
|
||||||
|
.IP -
|
||||||
|
instruction labels are only visible inside one procedure, so they can
|
||||||
|
not be referenced in other modules
|
||||||
|
.IP -
|
||||||
|
the names are not very suggestive anyway, as they must be integer numbers
|
||||||
|
.IP -
|
||||||
|
the optimizer considerably changes the control structure of the program,
|
||||||
|
so there is really no one to one mapping of instruction labels in
|
||||||
|
the input and the output program.
|
||||||
|
.LP
|
||||||
|
As the optimizer combines all input modules into one module,
|
||||||
|
visibility problems may occur.
|
||||||
|
Two modules M1 and M2 can both define an identifier X (provided that
|
||||||
|
X is not externally visible in any of these modules).
|
||||||
|
If M1 and M2 are combined into one module M, two distinct
|
||||||
|
entities with the same name would exist in M, which
|
||||||
|
is not allowed.
|
||||||
|
.[~[
|
||||||
|
tanenbaum machine architecture
|
||||||
|
.], section 11.1.4.3]
|
||||||
|
In these cases, CA invents a new unique name for one of the entities.
|
||||||
|
.NH 2
|
||||||
|
Implementation
|
||||||
|
.PP
|
||||||
|
CA first reads the files containing the procedure and global variable names
|
||||||
|
and stores the names in two tables.
|
||||||
|
It scans these tables to make sure that all names are different.
|
||||||
|
Subsequently it reads the EM text, one procedure at a time,
|
||||||
|
and outputs it in CAL format.
|
||||||
|
The major part of the code that does the latter transformation
|
||||||
|
is adapted from the EM Peephole Optimizer.
|
||||||
|
.PP
|
||||||
|
The main problem of the implementation of CA is to
|
||||||
|
assure that the visibility rules are obeyed.
|
||||||
|
If an identifier must be externally visible (i.e.
|
||||||
|
it was externally visible in the input program)
|
||||||
|
and the identifier is defined (in the output program) before
|
||||||
|
being referenced,
|
||||||
|
an EXA or EXP pseudo must be generated for it.
|
||||||
|
(Note that the optimizer may change the order of definitions and
|
||||||
|
references, so some pseudos may be needed that were not
|
||||||
|
present in the input program).
|
||||||
|
On the other hand, an identifier may be only internally visible.
|
||||||
|
If such an identifier is referenced before being defined,
|
||||||
|
an INA or INP pseudo must be emitted prior to its first reference.
|
||||||
6
doc/ego/cf/.distr
Normal file
6
doc/ego/cf/.distr
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
cf1
|
||||||
|
cf2
|
||||||
|
cf3
|
||||||
|
cf4
|
||||||
|
cf5
|
||||||
|
cf6
|
||||||
94
doc/ego/cf/cf1
Normal file
94
doc/ego/cf/cf1
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
.bp
|
||||||
|
.NH
|
||||||
|
The Control Flow Phase
|
||||||
|
.PP
|
||||||
|
In the previous chapter we described the intermediate
|
||||||
|
code of the global optimizer.
|
||||||
|
We also specified which part of this code
|
||||||
|
was constructed by the IC phase of the optimizer.
|
||||||
|
The Control Flow Phase (\fICF\fR) does
|
||||||
|
the remainder of the job,
|
||||||
|
i.e. it determines:
|
||||||
|
.IP -
|
||||||
|
the control flow graphs
|
||||||
|
.IP -
|
||||||
|
the loop tables
|
||||||
|
.IP -
|
||||||
|
the calling, change and use attributes of
|
||||||
|
the procedure table entries
|
||||||
|
.LP
|
||||||
|
CF operates on one procedure at a time.
|
||||||
|
For every procedure it first reads the EM instructions
|
||||||
|
from the EM-text file and groups them into basic blocks.
|
||||||
|
For every basic block, its successors and
|
||||||
|
predecessors are determined,
|
||||||
|
resulting in the control flow graph.
|
||||||
|
Next, the immediate dominator of every basic block
|
||||||
|
is computed.
|
||||||
|
Using these dominators, any loop in the
|
||||||
|
procedure is detected.
|
||||||
|
Finally, interprocedural analysis is done,
|
||||||
|
after which we will know the global effects of
|
||||||
|
every procedure call on its environment.
|
||||||
|
.sp
|
||||||
|
CF uses the same internal data structures
|
||||||
|
for the procedure table and object table as IC.
|
||||||
|
.NH 2
|
||||||
|
Partitioning into basic blocks
|
||||||
|
.PP
|
||||||
|
With regard to flow of control, we distinguish
|
||||||
|
three kinds of EM instructions:
|
||||||
|
jump instructions, instruction label definitions and
|
||||||
|
normal instructions.
|
||||||
|
Jump instructions are all conditional or unconditional
|
||||||
|
branch instructions,
|
||||||
|
the case instructions (CSA/CSB)
|
||||||
|
and the RET (return) instruction.
|
||||||
|
A procedure call (CAL) is not considered to be a jump.
|
||||||
|
A defining occurrence of an instruction label
|
||||||
|
is regarded as an EM instruction.
|
||||||
|
.PP
|
||||||
|
An instruction starts
|
||||||
|
a new basic block, in any of the following cases:
|
||||||
|
.IP 1.
|
||||||
|
It is the first instruction of a procedure
|
||||||
|
.IP 2.
|
||||||
|
It is the first of a list of instruction label
|
||||||
|
defining occurrences
|
||||||
|
.IP 3.
|
||||||
|
It follows a jump
|
||||||
|
.LP
|
||||||
|
If there are several consecutive instruction labels
|
||||||
|
(which is highly unusual),
|
||||||
|
all of them are put in the same basic block.
|
||||||
|
Note that several cases may overlap,
|
||||||
|
e.g. a label definition at the beginning of a procedure
|
||||||
|
or a label following a jump.
|
||||||
|
.PP
|
||||||
|
A simple Finite State Machine is used to model
|
||||||
|
the above rules.
|
||||||
|
It also recognizes the end of a procedure,
|
||||||
|
marked by an END pseudo.
|
||||||
|
The basic blocks are stored internally as a doubly linked
|
||||||
|
linear list.
|
||||||
|
The blocks are linked in textual order.
|
||||||
|
Every node of this list has the attributes described
|
||||||
|
in the previous chapter (see syntax rule for
|
||||||
|
basic_block).
|
||||||
|
Furthermore, every node contains a pointer to its
|
||||||
|
EM instructions,
|
||||||
|
which are represented internally
|
||||||
|
as a linear, doubly linked list,
|
||||||
|
just as in the IC phase.
|
||||||
|
However, instead of one list per procedure (as in IC)
|
||||||
|
there is now one list per basic block.
|
||||||
|
.PP
|
||||||
|
On the fly, a table is build that maps
|
||||||
|
every label identifier to the label definition
|
||||||
|
instruction.
|
||||||
|
This table is used for computing the control flow.
|
||||||
|
The table is stored as a dynamically allocated array.
|
||||||
|
The length of the array is the number of labels
|
||||||
|
of the current procedure;
|
||||||
|
this value can be found in the procedure table,
|
||||||
|
where it was stored by IC.
|
||||||
50
doc/ego/cf/cf2
Normal file
50
doc/ego/cf/cf2
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
.NH 2
|
||||||
|
Control Flow
|
||||||
|
.PP
|
||||||
|
A \fIsuccessor\fR of a basic block B is a block C
|
||||||
|
that can be executed immediately after B.
|
||||||
|
C is said to be a \fIpredecessor\fR of B.
|
||||||
|
A block ending with a RET instruction
|
||||||
|
has no successors.
|
||||||
|
Such a block is called a \fIreturn block\fR.
|
||||||
|
Any block that has no predecessors cannot be
|
||||||
|
executed at all (i.e. it is unreachable),
|
||||||
|
unless it is the first block of a procedure,
|
||||||
|
called the \fIprocedure entry block\fR.
|
||||||
|
.PP
|
||||||
|
Internally, the successor and predecessor
|
||||||
|
attributes of a basic block are stored as \fIsets\fR.
|
||||||
|
Alternatively, one may regard all these
|
||||||
|
sets of all basic blocks as a conceptual \fIgraph\fR,
|
||||||
|
in which there is an edge from B to C if C
|
||||||
|
is in the successor set of B.
|
||||||
|
We call this conceptual graph
|
||||||
|
the \fIControl Flow Graph\fR.
|
||||||
|
.PP
|
||||||
|
The only successor of a basic block ending on an
|
||||||
|
unconditional branch instruction is the block that
|
||||||
|
contains the label definition of the target of the jump.
|
||||||
|
The target instruction can be found via the LAB_ID
|
||||||
|
that is the operand of the jump instruction,
|
||||||
|
by using the label-map table mentioned
|
||||||
|
above.
|
||||||
|
If the last instruction of a block is a
|
||||||
|
conditional jump,
|
||||||
|
the successors are the target block and the textually
|
||||||
|
next block.
|
||||||
|
The last instruction can also be a case jump
|
||||||
|
instruction (CSA or CSB).
|
||||||
|
We then analyze the case descriptor,
|
||||||
|
to find all possible target instructions
|
||||||
|
and their associated blocks.
|
||||||
|
We require the case descriptor to be allocated in
|
||||||
|
a ROM, so it cannot be changed dynamically.
|
||||||
|
A case jump via an alterable descriptor could in principle
|
||||||
|
go to any label in the program.
|
||||||
|
In the presence of such an uncontrolled jump,
|
||||||
|
hardly any optimization can be done.
|
||||||
|
We do not expect any front end to generate such a descriptor,
|
||||||
|
however, because of the controlled nature
|
||||||
|
of case statements in high level languages.
|
||||||
|
If the basic block does not end in a jump instruction,
|
||||||
|
its only successor is the textually next block.
|
||||||
53
doc/ego/cf/cf3
Normal file
53
doc/ego/cf/cf3
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
.NH 2
|
||||||
|
Immediate dominators
|
||||||
|
.PP
|
||||||
|
A basic block B dominates a block C if every path
|
||||||
|
in the control flow graph from the procedure entry block
|
||||||
|
to C goes through B.
|
||||||
|
The immediate dominator of C is the closest dominator
|
||||||
|
of C on any path from the entry block.
|
||||||
|
See also
|
||||||
|
.[~[
|
||||||
|
aho compiler design
|
||||||
|
.], section 13.1.]
|
||||||
|
.PP
|
||||||
|
There are a number of algorithms to compute
|
||||||
|
the immediate dominator relation.
|
||||||
|
.IP 1.
|
||||||
|
Purdom and Moore give an algorithm that is
|
||||||
|
easy to program and easy to describe (although the
|
||||||
|
description they give is unreadable;
|
||||||
|
it is given in a very messy Algol60 program full of gotos).
|
||||||
|
.[
|
||||||
|
predominators
|
||||||
|
.]
|
||||||
|
.IP 2.
|
||||||
|
Aho and Ullman present a bitvector algorithm, which is also
|
||||||
|
easy to program and to understand.
|
||||||
|
(See
|
||||||
|
.[~[
|
||||||
|
aho compiler design
|
||||||
|
.], section 13.1.]).
|
||||||
|
.IP 3
|
||||||
|
Lengauer and Tarjan introduce a fast algorithm that is
|
||||||
|
hard to understand, yet remarkably easy to implement.
|
||||||
|
.[
|
||||||
|
lengauer dominators
|
||||||
|
.]
|
||||||
|
.LP
|
||||||
|
The Purdom-Moore algorithm is very slow if the
|
||||||
|
number of basic blocks in the flow graph is large.
|
||||||
|
The Aho-Ullman algorithm in fact computes the
|
||||||
|
dominator relation,
|
||||||
|
from which the immediate dominator relation can be computed
|
||||||
|
in time quadratic to the number of basic blocks, worst case.
|
||||||
|
The storage requirement is also quadratic to the number
|
||||||
|
of blocks.
|
||||||
|
The running time of the third algorithm is proportional
|
||||||
|
to:
|
||||||
|
.DS
|
||||||
|
(number of edges in the graph) * log(number of blocks).
|
||||||
|
.DE
|
||||||
|
We have chosen this algorithm because it is fast
|
||||||
|
(as shown by experiments done by Lengauer and Tarjan),
|
||||||
|
it is easy to program and requires little data space.
|
||||||
93
doc/ego/cf/cf4
Normal file
93
doc/ego/cf/cf4
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
.NH 2
|
||||||
|
Loop detection
|
||||||
|
.PP
|
||||||
|
Loops are detected by using the loop construction
|
||||||
|
algorithm of.
|
||||||
|
.[~[
|
||||||
|
aho compiler design
|
||||||
|
.], section 13.1.]
|
||||||
|
This algorithm uses \fIback edges\fR.
|
||||||
|
A back edge is an edge from B to C in the CFG,
|
||||||
|
whose head (C) dominates its tail (B).
|
||||||
|
The loop associated with this back edge
|
||||||
|
consists of C plus all nodes in the CFG
|
||||||
|
that can reach B without going through C.
|
||||||
|
.PP
|
||||||
|
As an example of how the algorithm works,
|
||||||
|
consider the piece of program of Fig. 4.1.
|
||||||
|
First just look at the program and try to
|
||||||
|
see what part of the code constitutes the loop.
|
||||||
|
.DS
|
||||||
|
loop
|
||||||
|
if cond then 1
|
||||||
|
-- lots of simple
|
||||||
|
-- assignment
|
||||||
|
-- statements 2 3
|
||||||
|
exit; -- exit loop
|
||||||
|
else
|
||||||
|
S; -- one statement
|
||||||
|
end if;
|
||||||
|
end loop;
|
||||||
|
|
||||||
|
Fig. 4.1 A misleading loop
|
||||||
|
.DE
|
||||||
|
Although a human being may be easily deceived
|
||||||
|
by the brackets "loop" and "end loop",
|
||||||
|
the loop detection algorithm will correctly
|
||||||
|
reply that only the test for "cond" and
|
||||||
|
the single statement in the false-part
|
||||||
|
of the if statement are part of the loop!
|
||||||
|
The statements in the true-part only get
|
||||||
|
executed once, so there really is no reason at all
|
||||||
|
to say they're part of the loop too.
|
||||||
|
The CFG contains one back edge, "3->1".
|
||||||
|
As node 3 cannot be reached from node 2,
|
||||||
|
the latter node is not part of the loop.
|
||||||
|
.PP
|
||||||
|
A source of problems with the algorithm is the fact
|
||||||
|
that different back edges may result in
|
||||||
|
the same loop.
|
||||||
|
Such an ill-structured loop is
|
||||||
|
called a \fImessy\fR loop.
|
||||||
|
After a loop has been constructed, it is checked
|
||||||
|
if it is really a new loop.
|
||||||
|
.PP
|
||||||
|
Loops can partly overlap, without one being nested
|
||||||
|
inside the other.
|
||||||
|
This is the case in the program of Fig. 4.2.
|
||||||
|
.DS
|
||||||
|
1: 1
|
||||||
|
S1;
|
||||||
|
2:
|
||||||
|
S2; 2
|
||||||
|
if cond then
|
||||||
|
goto 4;
|
||||||
|
S3; 3 4
|
||||||
|
goto 1;
|
||||||
|
4:
|
||||||
|
S4;
|
||||||
|
goto 1;
|
||||||
|
|
||||||
|
Fig. 4.2 Partly overlapping loops
|
||||||
|
.DE
|
||||||
|
There are two back edges "3->1" and "4->1",
|
||||||
|
resulting in the loops {1,2,3} and {1,2,4}.
|
||||||
|
With every basic block we associate a set of
|
||||||
|
all loops it is part of.
|
||||||
|
It is not sufficient just to record its
|
||||||
|
most enclosing loop.
|
||||||
|
.PP
|
||||||
|
After all loops of a procedure are detected, we determine
|
||||||
|
the nesting level of every loop.
|
||||||
|
Finally, we find all strong and firm blocks of the loop.
|
||||||
|
If the loop has only one back edge (i.e. it is not messy),
|
||||||
|
the set of firm blocks consists of the
|
||||||
|
head of this back edge and its dominators
|
||||||
|
in the loop (including the loop entry block).
|
||||||
|
A firm block is also strong if it is not a
|
||||||
|
successor of a block that may exit the loop;
|
||||||
|
a block may exit a loop if it has an (immediate) successor
|
||||||
|
that is not part of the loop.
|
||||||
|
For messy loops we do not determine the strong
|
||||||
|
and firm blocks. These loops are expected
|
||||||
|
to occur very rarely.
|
||||||
82
doc/ego/cf/cf5
Normal file
82
doc/ego/cf/cf5
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
.NH 2
|
||||||
|
Interprocedural analysis
|
||||||
|
.PP
|
||||||
|
It is often desirable to know the effects
|
||||||
|
a procedure call may have.
|
||||||
|
The optimization below is only possible if
|
||||||
|
we know for sure that the call to P cannot
|
||||||
|
change A.
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
A := 10; A:= 10;
|
||||||
|
P; -- procedure call --> P;
|
||||||
|
B := A + 2; B := 12;
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
Although it is not possible to predict exactly
|
||||||
|
all the effects a procedure call has, we may
|
||||||
|
determine a kind of upper bound for it.
|
||||||
|
So we compute all variables that may be
|
||||||
|
changed by P, although they need not be
|
||||||
|
changed at every invocation of P.
|
||||||
|
We can get hold of this set by just looking
|
||||||
|
at all assignment (store) instructions
|
||||||
|
in the body of P.
|
||||||
|
EM also has a set of \fIindirect\fR assignment
|
||||||
|
instructions,
|
||||||
|
i.e. assignment through a pointer variable.
|
||||||
|
In general, it is not possible to determine
|
||||||
|
which variable is affected by such an assignment.
|
||||||
|
In these cases, we just record the fact that P
|
||||||
|
does an indirect assignment.
|
||||||
|
Note that this does not mean that all variables
|
||||||
|
are potentially affected, as the front ends
|
||||||
|
may generate messages telling that certain
|
||||||
|
variables can never be accessed indirectly.
|
||||||
|
We also set a flag if P does a use (load) indirect.
|
||||||
|
Note that we only have to look at \fIglobal\fR
|
||||||
|
variables.
|
||||||
|
If P changes or uses any of its locals,
|
||||||
|
this has no effect on its environment.
|
||||||
|
Local variables of a lexically enclosing
|
||||||
|
procedure can only be accessed indirectly.
|
||||||
|
.PP
|
||||||
|
A procedure P may of course call another procedure.
|
||||||
|
To determine the effects of a call to P,
|
||||||
|
we also must know the effects of a call to the second procedure.
|
||||||
|
This second one may call a third one, and so on.
|
||||||
|
Effectively, we need to compute the \fItransitive closure\fR
|
||||||
|
of the effects.
|
||||||
|
To do this, we determine for every procedure
|
||||||
|
which other procedures it calls.
|
||||||
|
This set is the "calling" attribute of a procedure.
|
||||||
|
One may regard all these sets as a conceptual graph,
|
||||||
|
in which there is an edge from P to Q
|
||||||
|
if Q is in the calling set of P. This graph will
|
||||||
|
be referred to as the \fIcall graph\fR.
|
||||||
|
(Note the resemblance with the control flow graph).
|
||||||
|
.PP
|
||||||
|
We can detect which procedures are called by P
|
||||||
|
by looking at all CAL instructions in its body.
|
||||||
|
Unfortunately, a procedure may also be
|
||||||
|
called indirectly, via a CAI instruction.
|
||||||
|
Yet, only procedures that are used as operand of an LPI
|
||||||
|
instruction can be called indirect,
|
||||||
|
because this is the only way to take the address of a procedure.
|
||||||
|
We determine for every procedure whether it does
|
||||||
|
a CAI instruction.
|
||||||
|
We also build a set of all procedures used as
|
||||||
|
operand of an LPI.
|
||||||
|
.sp
|
||||||
|
After all procedures have been processed (i.e. all CFGs
|
||||||
|
are constructed, all loops are detected,
|
||||||
|
all procedures are analyzed to see which variables
|
||||||
|
they may change, which procedures they call,
|
||||||
|
whether they do a CAI or are used in an LPI) the
|
||||||
|
transitive closure of all interprocedural
|
||||||
|
information is computed.
|
||||||
|
During the same process,
|
||||||
|
the calling set of every procedure that uses a CAI
|
||||||
|
is extended with the above mentioned set of all
|
||||||
|
procedures that can be called indirect.
|
||||||
21
doc/ego/cf/cf6
Normal file
21
doc/ego/cf/cf6
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
.NH 2
|
||||||
|
Source files
|
||||||
|
.PP
|
||||||
|
The sources of CF are in the following files and packages:
|
||||||
|
.IP cf.h: 14
|
||||||
|
declarations of global variables and data structures
|
||||||
|
.IP cf.c:
|
||||||
|
the routine main; interprocedural analysis;
|
||||||
|
transitive closure
|
||||||
|
.IP succ:
|
||||||
|
control flow (successor and predecessor)
|
||||||
|
.IP idom:
|
||||||
|
immediate dominators
|
||||||
|
.IP loop:
|
||||||
|
loop detection
|
||||||
|
.IP get:
|
||||||
|
read object and procedure table;
|
||||||
|
read EM text and partition it into basic blocks
|
||||||
|
.IP put:
|
||||||
|
write tables, CFGs and EM text
|
||||||
|
.LP
|
||||||
1
doc/ego/cj/.distr
Normal file
1
doc/ego/cj/.distr
Normal file
@ -0,0 +1 @@
|
|||||||
|
cj1
|
||||||
144
doc/ego/cj/cj1
Normal file
144
doc/ego/cj/cj1
Normal file
@ -0,0 +1,144 @@
|
|||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
Cross jumping
|
||||||
|
.NH 2
|
||||||
|
Introduction
|
||||||
|
.PP
|
||||||
|
The "Cross Jumping" optimization technique (CJ)
|
||||||
|
.[
|
||||||
|
wulf design optimizing compiler
|
||||||
|
.]
|
||||||
|
is basically a space optimization technique. It looks for pairs of
|
||||||
|
basic blocks (B1,B2), for which:
|
||||||
|
.DS
|
||||||
|
SUCC(B1) = SUCC(B2) = {S}
|
||||||
|
.DE
|
||||||
|
(So B1 and B2 both have one and the same successor).
|
||||||
|
If the last few non-branch instructions are the same for B1 and B2,
|
||||||
|
one such sequence can be eliminated.
|
||||||
|
.DS
|
||||||
|
Pascal:
|
||||||
|
|
||||||
|
if cond then
|
||||||
|
S1
|
||||||
|
S3
|
||||||
|
else
|
||||||
|
S2
|
||||||
|
S3
|
||||||
|
|
||||||
|
(pseudo) EM:
|
||||||
|
.TS
|
||||||
|
l l l.
|
||||||
|
TEST COND TEST COND
|
||||||
|
BNE *1 BNE *1
|
||||||
|
S1 S1
|
||||||
|
S3 ---> BRA *2
|
||||||
|
BRA *2 1:
|
||||||
|
1: S2
|
||||||
|
S2 2:
|
||||||
|
S3 S3
|
||||||
|
2:
|
||||||
|
.TE
|
||||||
|
|
||||||
|
Fig. 9.1 An example of Cross Jumping
|
||||||
|
.DE
|
||||||
|
As the basic blocks have the same successor,
|
||||||
|
at least one of them ends in an unconditional branch instruction (BRA).
|
||||||
|
Hence no extra branch instruction is ever needed, just the target
|
||||||
|
of an existing branch needs to be changed; neither the program size
|
||||||
|
nor the execution time will ever increase.
|
||||||
|
In general, the execution time will remain the same, unless
|
||||||
|
further optimizations can be applied because of this optimization.
|
||||||
|
.PP
|
||||||
|
This optimization is particularly effective,
|
||||||
|
because it cannot always be done by the programmer at the source level,
|
||||||
|
as demonstrated by the Fig. 8.2.
|
||||||
|
.DS
|
||||||
|
Pascal:
|
||||||
|
|
||||||
|
if cond then
|
||||||
|
x := f(4)
|
||||||
|
else
|
||||||
|
x := g(5)
|
||||||
|
|
||||||
|
|
||||||
|
EM:
|
||||||
|
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
... ...
|
||||||
|
LOC 4 LOC 5
|
||||||
|
CAL F CAL G
|
||||||
|
ASP 2 ASP 2
|
||||||
|
LFR 2 LFR 2
|
||||||
|
STL X STL X
|
||||||
|
.TE
|
||||||
|
|
||||||
|
Fig. 9.2 Effectiveness of Cross Jumping
|
||||||
|
.DE
|
||||||
|
At the source level there is no common tail,
|
||||||
|
but at the EM level there is a common tail.
|
||||||
|
.NH 2
|
||||||
|
Implementation
|
||||||
|
.PP
|
||||||
|
The implementation of cross jumping is rather straightforward.
|
||||||
|
The technique is applied to one procedure at a time.
|
||||||
|
The control flow graph of the procedure
|
||||||
|
is scanned for pairs of basic blocks
|
||||||
|
with the same (single) successor and with common tails.
|
||||||
|
Note that there may be more than two such blocks (e.g. as the result
|
||||||
|
of a case statement).
|
||||||
|
This is dealt with by repeating the entire process until no
|
||||||
|
further optimizations can de done for the current procedure.
|
||||||
|
.sp
|
||||||
|
If a suitable pair of basic blocks has been found, the control flow
|
||||||
|
graph must be altered. One of the basic
|
||||||
|
blocks must be split into two.
|
||||||
|
The control flow graphs before and after the optimization are shown
|
||||||
|
in Fig. 9.3 and Fig. 9.4.
|
||||||
|
.DS
|
||||||
|
.ft 5
|
||||||
|
|
||||||
|
-------- --------
|
||||||
|
| | | |
|
||||||
|
| S1 | | S2 |
|
||||||
|
| S3 | | S3 |
|
||||||
|
| | | |
|
||||||
|
-------- --------
|
||||||
|
| |
|
||||||
|
|------------------|--------------------|
|
||||||
|
|
|
||||||
|
v
|
||||||
|
.ft R
|
||||||
|
|
||||||
|
Fig. 9.3 CFG before optimization
|
||||||
|
.DE
|
||||||
|
.DS
|
||||||
|
.ft 5
|
||||||
|
-------- --------
|
||||||
|
| | | |
|
||||||
|
| S1 | | S2 |
|
||||||
|
| | | |
|
||||||
|
-------- --------
|
||||||
|
| |
|
||||||
|
|--------------------<------------------|
|
||||||
|
v
|
||||||
|
--------
|
||||||
|
| |
|
||||||
|
| S3 |
|
||||||
|
| |
|
||||||
|
--------
|
||||||
|
|
|
||||||
|
v
|
||||||
|
.ft R
|
||||||
|
|
||||||
|
Fig. 9.4 CFG after optimization
|
||||||
|
.DE
|
||||||
|
Some attributes of the three resulting blocks (such as immediate dominator)
|
||||||
|
are updated.
|
||||||
|
.PP
|
||||||
|
In some cases, cross jumping might split the computation of an expression
|
||||||
|
into two, by inserting a branch somewhere in the middle.
|
||||||
|
Most code generators will generate very poor assembly code when
|
||||||
|
presented with such EM code.
|
||||||
|
Therefor, cross jumping is not performed in these cases.
|
||||||
5
doc/ego/cs/.distr
Normal file
5
doc/ego/cs/.distr
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
cs1
|
||||||
|
cs2
|
||||||
|
cs3
|
||||||
|
cs4
|
||||||
|
cs5
|
||||||
45
doc/ego/cs/cs1
Normal file
45
doc/ego/cs/cs1
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
Common subexpression elimination
|
||||||
|
.NH 2
|
||||||
|
Introduction
|
||||||
|
.PP
|
||||||
|
The Common Subexpression Elimination optimization technique (CS)
|
||||||
|
tries to eliminate multiple computations of EM expressions
|
||||||
|
that yield the same result.
|
||||||
|
It places the result of one such computation
|
||||||
|
in a temporary variable,
|
||||||
|
and replaces the other computations by a reference
|
||||||
|
to this temporary variable.
|
||||||
|
The primary goal of this technique is to decrease
|
||||||
|
the execution time of the program,
|
||||||
|
but in general it will save space too.
|
||||||
|
.PP
|
||||||
|
As an example of the application of Common Subexpression Elimination,
|
||||||
|
consider the piece of program in Fig. 7.1(a).
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l l.
|
||||||
|
x := a * b; TMP := a * b; x := a * b;
|
||||||
|
CODE; x := TMP; CODE
|
||||||
|
y := c + a * b; CODE y := x;
|
||||||
|
y := c + TMP;
|
||||||
|
|
||||||
|
(a) (b) (c)
|
||||||
|
.TE
|
||||||
|
|
||||||
|
Fig. 7.1 Examples of Common Subexpression Elimination
|
||||||
|
.DE
|
||||||
|
If neither a nor b is changed in CODE,
|
||||||
|
the instructions can be replaced by those of Fig. 7.1(b),
|
||||||
|
which saves one multiplication,
|
||||||
|
but costs an extra store instruction.
|
||||||
|
If the value of x is not changed in CODE either,
|
||||||
|
the instructions can be replaced by those of Fig. 7.1(c).
|
||||||
|
In this case
|
||||||
|
the extra store is not needed.
|
||||||
|
.PP
|
||||||
|
In the following sections we will describe
|
||||||
|
which transformations are done
|
||||||
|
by CS and how this phase
|
||||||
|
was implemented.
|
||||||
86
doc/ego/cs/cs2
Normal file
86
doc/ego/cs/cs2
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
.NH 2
|
||||||
|
Specification of the Common Subexpression Elimination phase
|
||||||
|
.PP
|
||||||
|
In this section we will describe
|
||||||
|
the window
|
||||||
|
through which CS examines the code,
|
||||||
|
the expressions recognized by CS,
|
||||||
|
and finally the changes made to the code.
|
||||||
|
.NH 3
|
||||||
|
The working window
|
||||||
|
.PP
|
||||||
|
The CS algorithm is applied to the
|
||||||
|
largest sequence of textually adjacent basic blocks
|
||||||
|
B1,..,Bn, for which
|
||||||
|
.DS
|
||||||
|
PRED(Bj) = {Bj-1}, j = 2,..,n.
|
||||||
|
.DE
|
||||||
|
Intuitively, this window consists of straight line code,
|
||||||
|
with only one entry point (at the beginning); it may
|
||||||
|
contain jumps, which should all have their targets outside the window.
|
||||||
|
This is illustrated in Fig. 7.2.
|
||||||
|
.DS
|
||||||
|
x := a * b; (1)
|
||||||
|
if x < 10 then (2)
|
||||||
|
y := a * b; (3)
|
||||||
|
|
||||||
|
Fig. 7.2 The working window of CS
|
||||||
|
.DE
|
||||||
|
Line (2) can only be executed after line (1).
|
||||||
|
Likewise, line (3) can only be executed after
|
||||||
|
line (2).
|
||||||
|
Both a and b have the same values at line (1) and at line (3).
|
||||||
|
.PP
|
||||||
|
Larger windows were avoided.
|
||||||
|
In Fig. 7.3, the value of a at line (4) may have been obtained
|
||||||
|
at more than one point.
|
||||||
|
.DS
|
||||||
|
x := a * b; (1)
|
||||||
|
if x < 10 then (2)
|
||||||
|
a := 100; (3)
|
||||||
|
y := a * b; (4)
|
||||||
|
|
||||||
|
Fig. 7.3 Several working windows
|
||||||
|
.DE
|
||||||
|
.NH 3
|
||||||
|
Recognized expressions.
|
||||||
|
.PP
|
||||||
|
The computations eliminated by CS need not be normal expressions
|
||||||
|
(like "a * b"),
|
||||||
|
but can even consist of a single operand that is expensive to access,
|
||||||
|
such as an array element or a record field.
|
||||||
|
If an array element is used,
|
||||||
|
its address is computed implicitly.
|
||||||
|
CS is able to eliminate either the element itself or its
|
||||||
|
address, whichever one is most profitable.
|
||||||
|
A variable of a textually enclosing procedure may also be
|
||||||
|
expensive to access, depending on the lexical level difference.
|
||||||
|
.NH 3
|
||||||
|
Transformations
|
||||||
|
.PP
|
||||||
|
CS creates a new temporary local variable (TMP)
|
||||||
|
for every eliminated expression,
|
||||||
|
unless it is able to use an existing local variable.
|
||||||
|
It emits code to initialize this variable with the
|
||||||
|
result of the expression.
|
||||||
|
Most recurrences of the expression
|
||||||
|
can simply be replaced by a reference to TMP.
|
||||||
|
If the address of an array element is recognized as
|
||||||
|
a common subexpression,
|
||||||
|
references to the element itself are replaced by
|
||||||
|
indirect references through TMP (see Fig. 7.4).
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l l.
|
||||||
|
x := A[i]; TMP := &A[i];
|
||||||
|
. . . --> x := *TMP;
|
||||||
|
A[i] := y; . . .
|
||||||
|
*TMP := y;
|
||||||
|
.TE
|
||||||
|
|
||||||
|
Fig. 7.4 Elimination of an array address computation
|
||||||
|
.DE
|
||||||
|
Here, '&' is the 'address of' operator,
|
||||||
|
and unary '*' is the indirection operator.
|
||||||
|
(Note that EM actually has different instructions to do
|
||||||
|
a use-indirect or an assign-indirect.)
|
||||||
250
doc/ego/cs/cs3
Normal file
250
doc/ego/cs/cs3
Normal file
@ -0,0 +1,250 @@
|
|||||||
|
.NH 2
|
||||||
|
Implementation
|
||||||
|
.PP
|
||||||
|
.NH 3
|
||||||
|
The value number method
|
||||||
|
.PP
|
||||||
|
To determine whether two expressions have the same result,
|
||||||
|
there must be some way to determine whether their operands have
|
||||||
|
the same values.
|
||||||
|
We use a system of \fIvalue numbers\fP
|
||||||
|
.[
|
||||||
|
kennedy data flow analysis
|
||||||
|
.]
|
||||||
|
in which each distinct value of whatever type,
|
||||||
|
created or used within the working window,
|
||||||
|
receives a unique identifying number, its value number.
|
||||||
|
Two items have the same value number if and only if,
|
||||||
|
based only upon information from the instructions in the window,
|
||||||
|
their values are provably identical.
|
||||||
|
For example, after processing the statement
|
||||||
|
.DS
|
||||||
|
a := 4;
|
||||||
|
.DE
|
||||||
|
the variable a and the constant 4 have the same value number.
|
||||||
|
.PP
|
||||||
|
The value number of the result of an expression depends only
|
||||||
|
on the kind of operator and the value number(s) of the operand(s).
|
||||||
|
The expressions need not be textually equal, as shown in Fig. 7.5.
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
a := c; (1)
|
||||||
|
use(a * b); (2)
|
||||||
|
d := b; (3)
|
||||||
|
use(c * d); (4)
|
||||||
|
.TE
|
||||||
|
|
||||||
|
Fig. 7.5 Different expressions with the same value number
|
||||||
|
.DE
|
||||||
|
At line (1) a receives the same value number as c.
|
||||||
|
At line (2) d receives the same value number as b.
|
||||||
|
At line (4) the expression "c * d" receives the same value number
|
||||||
|
as the expression "a * b" at line (2),
|
||||||
|
because the value numbers of their left and right operands are the same,
|
||||||
|
and the operator (*) is the same.
|
||||||
|
.PP
|
||||||
|
As another example of the value number method, consider Fig. 7.6.
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
use(a * b); (1)
|
||||||
|
a := 123; (2)
|
||||||
|
use(a * b); (3)
|
||||||
|
.TE
|
||||||
|
|
||||||
|
Fig. 7.6 Identical expressions with the different value numbers
|
||||||
|
.DE
|
||||||
|
Although textually the expressions "a * b" in line 1 and line 3 are equal,
|
||||||
|
a will have different value numbers at line 3 and line 1.
|
||||||
|
The two expressions will not mistakenly be recognized as equivalent.
|
||||||
|
.NH 3
|
||||||
|
Entities
|
||||||
|
.PP
|
||||||
|
The Value Number Method distinguishes between operators and operands.
|
||||||
|
The value numbers of operands are stored in a table,
|
||||||
|
called the \fIsymbol table\fR.
|
||||||
|
The value number of a subexpression depends on the
|
||||||
|
(root) operator of the expression and on the value numbers
|
||||||
|
of its operands.
|
||||||
|
A table of "available expressions" is used to do this mapping.
|
||||||
|
.PP
|
||||||
|
CS recognizes the following kinds of EM operands, called \fIentities\fR:
|
||||||
|
.DS
|
||||||
|
- constant
|
||||||
|
- local variable
|
||||||
|
- external variable
|
||||||
|
- indirectly accessed entity
|
||||||
|
- offsetted entity
|
||||||
|
- address of local variable
|
||||||
|
- address of external variable
|
||||||
|
- address of offsetted entity
|
||||||
|
- address of local base
|
||||||
|
- address of argument base
|
||||||
|
- array element
|
||||||
|
- procedure identifier
|
||||||
|
- floating zero
|
||||||
|
- local base
|
||||||
|
- heap pointer
|
||||||
|
- ignore mask
|
||||||
|
.DE
|
||||||
|
.LP
|
||||||
|
Whenever a new entity is encountered in the working window,
|
||||||
|
it is entered in the symbol table and given a brand new value number.
|
||||||
|
Most entities have attributes (e.g. the offset in
|
||||||
|
the current stackframe for local variables),
|
||||||
|
which are also stored in the symbol table.
|
||||||
|
.PP
|
||||||
|
An entity is called static if its value cannot be changed
|
||||||
|
(e.g. a constant or an address).
|
||||||
|
.NH 3
|
||||||
|
Parsing expressions
|
||||||
|
.PP
|
||||||
|
Common subexpressions are recognized by simulating the behaviour
|
||||||
|
of the EM machine.
|
||||||
|
The EM code is parsed from left to right;
|
||||||
|
as EM is postfix code, this is a bottom up parse.
|
||||||
|
At any point the current state of the EM runtime stack is
|
||||||
|
reflected by a simulated "fake stack",
|
||||||
|
containing descriptions of the parsed operands and expressions.
|
||||||
|
A descriptor consists of:
|
||||||
|
.DS
|
||||||
|
(1) the value number of the operand or expression
|
||||||
|
(2) the size of the operand or expression
|
||||||
|
(3) a pointer to the first line of EM-code
|
||||||
|
that constitutes the operand or expression
|
||||||
|
.DE
|
||||||
|
Note that operands may consist of several EM instructions.
|
||||||
|
Whenever an operator is encountered, the
|
||||||
|
descriptors of its operands are on top of the fake stack.
|
||||||
|
The operator and the value numbers of the operands
|
||||||
|
are used as indices in the table of available expressions,
|
||||||
|
to determine the value number of the expression.
|
||||||
|
.PP
|
||||||
|
During the parsing process,
|
||||||
|
we keep track of the first line of each expression;
|
||||||
|
we need this information when we decide to eliminate the expression.
|
||||||
|
.NH 3
|
||||||
|
Updating entities
|
||||||
|
.PP
|
||||||
|
An entity is assigned a value number when it is
|
||||||
|
used for the first time
|
||||||
|
in the working window.
|
||||||
|
If the entity is used as left hand side of an assignment,
|
||||||
|
it gets the value number of the right hand side.
|
||||||
|
Sometimes the effects of an instruction on an entity cannot
|
||||||
|
be determined exactly;
|
||||||
|
the current value and value number of the entity may become
|
||||||
|
inconsistent.
|
||||||
|
Hence the current value number must be forgotten.
|
||||||
|
This is achieved by giving the entity a new value number
|
||||||
|
that was not used before.
|
||||||
|
The entity is said to be \fIkilled\fR.
|
||||||
|
.PP
|
||||||
|
As information is lost when an entity is killed,
|
||||||
|
CS tries to save as many entities as possible.
|
||||||
|
In case of an indirect assignment through a pointer,
|
||||||
|
some analysis is done to see which variables cannot be altered.
|
||||||
|
For a procedure call, the interprocedural information contained
|
||||||
|
in the procedure table is used to restrict the set of entities that may
|
||||||
|
be changed by the call.
|
||||||
|
Local variables for which the front end generated
|
||||||
|
a register message can never be changed by an indirect assignment
|
||||||
|
or a procedure call.
|
||||||
|
.NH 3
|
||||||
|
Changing the EM text
|
||||||
|
.PP
|
||||||
|
When a new expression comes available,
|
||||||
|
it is checked whether its result is saved in a local
|
||||||
|
that may go in a register.
|
||||||
|
The last line of the expression must be followed
|
||||||
|
by a STL or SDL instruction
|
||||||
|
(depending on the size of the result)
|
||||||
|
and a register message must be present for
|
||||||
|
this local.
|
||||||
|
If there is such a local,
|
||||||
|
it is recorded in the available expressions table.
|
||||||
|
Each time a new occurrence of this expression
|
||||||
|
is found,
|
||||||
|
the value number of the local is compared against
|
||||||
|
the value number of the result.
|
||||||
|
If they are different the local cannot be used and is forgotten.
|
||||||
|
.PP
|
||||||
|
The available expressions are linked in a list.
|
||||||
|
New expressions are linked at the head of the list.
|
||||||
|
In this way expressions that are contained within other
|
||||||
|
expressions appear later in the list,
|
||||||
|
because EM-expressions are postfix.
|
||||||
|
The elimination process walks through the list,
|
||||||
|
starting at the head, to find the largest expressions first.
|
||||||
|
If an expression is eliminated,
|
||||||
|
any expression later on in the list, contained in the former expression,
|
||||||
|
is removed from the list,
|
||||||
|
as expressions can only be eliminated once.
|
||||||
|
.PP
|
||||||
|
A STL or SDL is emitted after the first occurrence of the expression,
|
||||||
|
unless there was an existing local variable that could hold the result.
|
||||||
|
.NH 3
|
||||||
|
Desirability analysis
|
||||||
|
.PP
|
||||||
|
Although the global optimizer works on EM code,
|
||||||
|
the goal is to improve the quality of the object code.
|
||||||
|
Therefore some machine-dependent information is needed
|
||||||
|
to decide whether it is desirable to
|
||||||
|
eliminate a given expression.
|
||||||
|
Because it is impossible for the CS phase to know
|
||||||
|
exactly what code will be generated,
|
||||||
|
some heuristics are used.
|
||||||
|
CS essentially looks for some special cases
|
||||||
|
that should not be eliminated.
|
||||||
|
These special cases can be turned on or off for a given machine,
|
||||||
|
as indicated in a machine descriptor file.
|
||||||
|
.PP
|
||||||
|
Some operators can sometimes be translated
|
||||||
|
into an addressing mode for the machine at hand.
|
||||||
|
Such an operator is only eliminated
|
||||||
|
if its operand is itself expensive,
|
||||||
|
i.e. it is not just a simple load.
|
||||||
|
The machine descriptor file contains a set of such operators.
|
||||||
|
.PP
|
||||||
|
Eliminating the loading of the Local Base or
|
||||||
|
the Argument Base by the LXL resp. LXA instruction
|
||||||
|
is only beneficial if the difference in lexical levels
|
||||||
|
exceeds a certain threshold.
|
||||||
|
The machine descriptor file contains this threshold.
|
||||||
|
.PP
|
||||||
|
Replacing a SAR or a LAR by an AAR followed by a LOI
|
||||||
|
may possibly increase the size of the object code.
|
||||||
|
We assume that this is only possible when the
|
||||||
|
size of the array element is greater than some limit.
|
||||||
|
.PP
|
||||||
|
There are back ends that can very efficiently translate
|
||||||
|
the index computing instruction sequence LOC SLI ADS.
|
||||||
|
If this is the case,
|
||||||
|
the SLI instruction between a LOC
|
||||||
|
and an ADS is not eliminated.
|
||||||
|
.PP
|
||||||
|
To handle unforseen cases, the descriptor file may also contain
|
||||||
|
a set of operators that should never be eliminated.
|
||||||
|
.NH 3
|
||||||
|
The algorithm
|
||||||
|
.PP
|
||||||
|
After these preparatory explanations,
|
||||||
|
the algorithm itself is easy to understand.
|
||||||
|
For each instruction within the current window,
|
||||||
|
the following steps are performed in the given order :
|
||||||
|
.IP 1.
|
||||||
|
Check if this instruction defines an entity.
|
||||||
|
If so, the set of entities is updated accordingly.
|
||||||
|
.IP 2.
|
||||||
|
Kill all entities that might be affected by this instruction.
|
||||||
|
.IP 3.
|
||||||
|
Simulate the instruction on the fake-stack.
|
||||||
|
If this instruction is an operator,
|
||||||
|
update the list of available expressions accordingly.
|
||||||
|
.PP
|
||||||
|
The result of this process is
|
||||||
|
a list of available expressions plus the information
|
||||||
|
needed to eliminate them.
|
||||||
|
Expressions that are desirable to eliminate are eliminated.
|
||||||
|
Next, the window is shifted and the process is repeated.
|
||||||
311
doc/ego/cs/cs4
Normal file
311
doc/ego/cs/cs4
Normal file
@ -0,0 +1,311 @@
|
|||||||
|
.NH 2
|
||||||
|
Implementation.
|
||||||
|
.PP
|
||||||
|
In this section we will discuss the implementation of the CS phase.
|
||||||
|
We will first describe the basic actions that are undertaken
|
||||||
|
by the algorithm, than the algorithm itself.
|
||||||
|
.NH 3
|
||||||
|
Partioning the EM instructions
|
||||||
|
.PP
|
||||||
|
There are over 100 EM instructions.
|
||||||
|
For our purpose we partition this huge set into groups of
|
||||||
|
instructions which can be more or less conveniently handled together.
|
||||||
|
.PP
|
||||||
|
There are groups for all sorts of load instructions:
|
||||||
|
simple loads, expensive loads, loads of an array element.
|
||||||
|
A load is considered \fIexpensive\fP when more than one EM instructions
|
||||||
|
are involved in loading it.
|
||||||
|
The load of a lexical entity is also considered expensive.
|
||||||
|
For instance: LOF is expensive, LAL is not.
|
||||||
|
LAR forms a group on its own,
|
||||||
|
because it is not only an expensive load,
|
||||||
|
but also implicitly includes the ternary operator AAR,
|
||||||
|
which computes the address of the array element.
|
||||||
|
.PP
|
||||||
|
There are groups for all sorts of operators:
|
||||||
|
unary, binary, and ternary.
|
||||||
|
The groups of operators are further partitioned according to the size
|
||||||
|
of their operand(s) and result.
|
||||||
|
.\" .PP
|
||||||
|
.\" The distinction between operators and expensive loads is not always clear.
|
||||||
|
.\" The ADP instruction for example,
|
||||||
|
.\" might seem a unary operator because it pops one item
|
||||||
|
.\" (a pointer) from the stack.
|
||||||
|
.\" However, two ADP-instructions which pop an item with the same value number
|
||||||
|
.\" need not have the same result,
|
||||||
|
.\" because the attributes (an offset, to be added to the pointer)
|
||||||
|
.\" can be different.
|
||||||
|
.\" Is it then a binary operator?
|
||||||
|
.\" That would give rise to the strange, and undesirable,
|
||||||
|
.\" situation that some binary operators pop two operands
|
||||||
|
.\" and others pop one.
|
||||||
|
.\" The conclusion is inevitable:
|
||||||
|
.\" we have been fooled by the name (ADd Pointer).
|
||||||
|
.\" The ADP-instruction is an expensive load.
|
||||||
|
.\" In this context LAF, meaning Load Address of oFfsetted,
|
||||||
|
.\" would have been a better name,
|
||||||
|
.\" corresponding to LOF, like LAL,
|
||||||
|
.\" Load Address of Local, corresponds to LOL.
|
||||||
|
.PP
|
||||||
|
There are groups for all sorts of stores:
|
||||||
|
direct, indirect, array element.
|
||||||
|
The SAR forms a group on its own for the same reason
|
||||||
|
as appeared with LAR.
|
||||||
|
.PP
|
||||||
|
The effect of the remaining instructions is less clear.
|
||||||
|
They do not help very much in parsing expressions or
|
||||||
|
in constructing our pseudo symboltable.
|
||||||
|
They are partitioned according to the following criteria:
|
||||||
|
.RS
|
||||||
|
.IP "-"
|
||||||
|
They change the value of an entity without using the stack
|
||||||
|
(e.g. ZRL, DEE).
|
||||||
|
.IP "-"
|
||||||
|
They are subroutine calls (CAI, CAL).
|
||||||
|
.IP "-"
|
||||||
|
They change the stack in some irreproduceable way (e.g. ASP, LFR, DUP).
|
||||||
|
.IP "-"
|
||||||
|
They have no effect whatever on the stack or on the entities.
|
||||||
|
This does not mean they can be deleted,
|
||||||
|
but they can be ignored for the moment
|
||||||
|
(e.g. MES, LIN, NOP).
|
||||||
|
.IP "-"
|
||||||
|
Their effect is too complicate too compute,
|
||||||
|
so we just assume worst case behaviour.
|
||||||
|
Hopefully, they do not occur very often.
|
||||||
|
(e.g. MON, STR, BLM).
|
||||||
|
.IP "-"
|
||||||
|
They signal the end of the basic block (e.g. BLT, RET, TRP).
|
||||||
|
.RE
|
||||||
|
.NH 3
|
||||||
|
Parsing expressions
|
||||||
|
.PP
|
||||||
|
To recognize expressions,
|
||||||
|
we simulate the behaviour of the EM machine,
|
||||||
|
by means of a fake-stack.
|
||||||
|
When we scan the instructions in sequential order,
|
||||||
|
we first encounter the instructions that load
|
||||||
|
the operands on the stack,
|
||||||
|
and then the instruction that indicates the operator,
|
||||||
|
because EM expressions are postfix.
|
||||||
|
When we find an instruction to load an operand,
|
||||||
|
we load on the fake-stack a struct with the following information:
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
(1) the value number of the operand
|
||||||
|
(2) the size of the operand
|
||||||
|
(3) a pointer to the first line of EM-code
|
||||||
|
that constitutes the operand
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
In most cases, (3) will point to the line
|
||||||
|
that loaded the operand (e.g. LOL, LOC),
|
||||||
|
i.e. there is only one line that refers to this operand,
|
||||||
|
but sometimes some information must be popped
|
||||||
|
to load the operand (e.g. LOI, LAR).
|
||||||
|
This information must have been pushed before,
|
||||||
|
so we also pop a pointer to the first line that pushed
|
||||||
|
the information.
|
||||||
|
This line is now the first line that defines the operand.
|
||||||
|
.PP
|
||||||
|
When we find the operator instruction,
|
||||||
|
we pop its operand(s) from the fake-stack.
|
||||||
|
The first line that defines the first operand is
|
||||||
|
now the first line of the expression.
|
||||||
|
We now have all information to determine
|
||||||
|
whether the just parsed expression has occurred before.
|
||||||
|
We also know the first and last line of the expression;
|
||||||
|
we need this when we decide to eliminate it.
|
||||||
|
Associated with each available expression is a set of
|
||||||
|
which the elements contains the first and last line of
|
||||||
|
a recurrence of this expression.
|
||||||
|
.PP
|
||||||
|
Not only will the operand(s) be popped from the fake-stack,
|
||||||
|
but the following will be pushed:
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
(1) the value number of the result
|
||||||
|
(2) the size of the result
|
||||||
|
(3) a pointer to the first line of the expression
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
In this way an item on the fake-stack always contains
|
||||||
|
the necessary information.
|
||||||
|
EM expressions are parsed bottum up.
|
||||||
|
.NH 3
|
||||||
|
Updating entities
|
||||||
|
.PP
|
||||||
|
As said before,
|
||||||
|
we build our private "symboltable",
|
||||||
|
while scanning the EM-instructions.
|
||||||
|
The behaviour of the EM-machine is not only reflected
|
||||||
|
in the fake-stack,
|
||||||
|
but also in the entities.
|
||||||
|
When an entity is created,
|
||||||
|
we do not yet know its value,
|
||||||
|
so we assign a brand new value number to it.
|
||||||
|
Each time a store-instruction is encountered,
|
||||||
|
we change the value number of the target entity of this store
|
||||||
|
to the value number of the token that was popped
|
||||||
|
from the fake-stack.
|
||||||
|
Because entities may overlap,
|
||||||
|
we must also "forget" the value numbers of entities
|
||||||
|
that might be affected by this store.
|
||||||
|
Each such entity will be \fIkilled\fP,
|
||||||
|
i.e. assigned a brand new valuenumber.
|
||||||
|
.PP
|
||||||
|
Because we lose information when we forget
|
||||||
|
the value number of an entity,
|
||||||
|
we try to save as much entities as possible.
|
||||||
|
When we store into an external,
|
||||||
|
we don't have to kill locals and vice versa.
|
||||||
|
Furthermore, we can see whether two locals or
|
||||||
|
two externals overlap,
|
||||||
|
because we know the offset from the local base,
|
||||||
|
resp. the offset within the data block,
|
||||||
|
and the size.
|
||||||
|
The situation becomes more complicated when we have
|
||||||
|
to consider indirection.
|
||||||
|
The worst case is that we store through an unknown pointer.
|
||||||
|
In that case we kill all entities except those locals
|
||||||
|
for which a so-called \fIregister message\fP has been generated;
|
||||||
|
this register message indicates that this local can never be
|
||||||
|
accessed indirectly.
|
||||||
|
If we know this pointer we can be more careful.
|
||||||
|
If it points to a local then the entity that is accessed through
|
||||||
|
this pointer can never overlap with an external.
|
||||||
|
If it points to an external this entity can never overlap with a local.
|
||||||
|
Furthermore, in the latter case,
|
||||||
|
we can find the data block this entity belongs to.
|
||||||
|
Since pointer arithmetic is only defined within a data block,
|
||||||
|
this entity can never overlap with entities that are known to
|
||||||
|
belong to another data block.
|
||||||
|
.PP
|
||||||
|
Not only after a store-instruction but also after a
|
||||||
|
subroutine-call it may be necessary to kill entities;
|
||||||
|
the subroutine may affect global variables or store
|
||||||
|
through a pointer.
|
||||||
|
If a subroutine is called that is not available as EM-text,
|
||||||
|
we assume worst case behaviour,
|
||||||
|
i.e. we kill all entities without register message.
|
||||||
|
.NH 3
|
||||||
|
Additions and replacements.
|
||||||
|
.PP
|
||||||
|
When a new expression comes available,
|
||||||
|
we check whether the result is saved in a local
|
||||||
|
that may go in a register.
|
||||||
|
The last line of the expression must be followed
|
||||||
|
by a STL or SDL instruction,
|
||||||
|
depending on the size of the result
|
||||||
|
(resp. WS and 2*WS),
|
||||||
|
and a register message must be present for
|
||||||
|
this local.
|
||||||
|
If we have found such a local,
|
||||||
|
we store a pointer to it with the available expression.
|
||||||
|
Each time a new occurrence of this expression
|
||||||
|
is found,
|
||||||
|
we compare the value number of the local against
|
||||||
|
the value number of the result.
|
||||||
|
When they are different we remove the pointer to it,
|
||||||
|
because we cannot use it.
|
||||||
|
.PP
|
||||||
|
The available expressions are singly linked in a list.
|
||||||
|
When a new expression comes available,
|
||||||
|
we link it at the head of the list.
|
||||||
|
In this way expressions that are contained within other
|
||||||
|
expressions appear later in the list,
|
||||||
|
because EM-expressions are postfix.
|
||||||
|
When we are going to eliminate expressions,
|
||||||
|
we walk through the list,
|
||||||
|
starting at the head, to find the largest expressions first.
|
||||||
|
When we decide to eliminate an expression,
|
||||||
|
we look at the expressions in the tail of the list,
|
||||||
|
starting from where we are now,
|
||||||
|
to delete expressions that are contained within
|
||||||
|
the chosen one because
|
||||||
|
we cannot eliminate an expression more than once.
|
||||||
|
.PP
|
||||||
|
When we are going to eliminate expressions,
|
||||||
|
and we do not have a local that holds the result,
|
||||||
|
we emit a STL or SDL after the line where the expression
|
||||||
|
was first found.
|
||||||
|
The other occurrences are simply removed,
|
||||||
|
unless they contain instructions that not only have
|
||||||
|
effect on the stack; e.g. messages, stores, calls.
|
||||||
|
Before each instruction that needs the result on the stack,
|
||||||
|
we emit a LOL or LDL.
|
||||||
|
When the expression was an AAR,
|
||||||
|
but the instruction was a LAR or a SAR,
|
||||||
|
we append a LOI resp. a STI of the number of bytes
|
||||||
|
in an array-element after each LOL/LDL.
|
||||||
|
.NH 3
|
||||||
|
Desirability analysis
|
||||||
|
.PP
|
||||||
|
Although the global optimizer works on EM code,
|
||||||
|
the goal is to improve the quality of the object code.
|
||||||
|
Therefore we need some machine dependent information
|
||||||
|
to decide whether it is desirable to
|
||||||
|
eliminate a given expression.
|
||||||
|
Because it is impossible for the CS phase to know
|
||||||
|
exactly what code will be generated,
|
||||||
|
we use some heuristics.
|
||||||
|
In most cases it will save time when we eliminate an
|
||||||
|
operator, so we just do it.
|
||||||
|
We only look for some special cases.
|
||||||
|
.PP
|
||||||
|
Some operators can in some cases be translated
|
||||||
|
into an addressing mode for the machine at hand.
|
||||||
|
We only eliminate such an operator,
|
||||||
|
when its operand is itself "expensive",
|
||||||
|
i.e. not just a simple load.
|
||||||
|
The user of the CS phase has to supply
|
||||||
|
a set of such operators.
|
||||||
|
.PP
|
||||||
|
Eliminating the loading of the Local Base or
|
||||||
|
the Argument Base by the LXL resp. LXA instruction
|
||||||
|
is only beneficial when the number of lexical levels
|
||||||
|
we have to go back exceeds a certain threshold.
|
||||||
|
This threshold will be different when registers
|
||||||
|
are saved by the back end.
|
||||||
|
The user must supply this threshold.
|
||||||
|
.PP
|
||||||
|
Replacing a SAR or a LAR by an AAR followed by a LOI
|
||||||
|
may possibly increase the size of the object code.
|
||||||
|
We assume that this is only possible when the
|
||||||
|
size of the array element is greater than some
|
||||||
|
(user-supplied) limit.
|
||||||
|
.PP
|
||||||
|
There are back ends that can very efficiently translate
|
||||||
|
the index computing instruction sequence LOC SLI ADS.
|
||||||
|
If this is the case,
|
||||||
|
we do not eliminate the SLI instruction between a LOC
|
||||||
|
and an ADS.
|
||||||
|
.PP
|
||||||
|
To handle unforeseen cases, the user may also supply
|
||||||
|
a set of operators that should never be eliminated.
|
||||||
|
.NH 3
|
||||||
|
The algorithm
|
||||||
|
.PP
|
||||||
|
After these preparatory explanations,
|
||||||
|
we can be short about the algorithm itself.
|
||||||
|
For each instruction within our window,
|
||||||
|
the following steps are performed in the order given:
|
||||||
|
.IP 1.
|
||||||
|
We check if this instructin defines an entity.
|
||||||
|
If this is the case the set of entities is updated accordingly.
|
||||||
|
.IP 2.
|
||||||
|
We kill all entities that might be affected by this instruction.
|
||||||
|
.IP 3.
|
||||||
|
The instruction is simulated on the fake-stack.
|
||||||
|
Copy propagation is done.
|
||||||
|
If this instruction is an operator,
|
||||||
|
we update the list of available expressions accordingly.
|
||||||
|
.PP
|
||||||
|
When we have processed all instructions this way,
|
||||||
|
we have built a list of available expressions plus the information we
|
||||||
|
need to eliminate them.
|
||||||
|
Those expressions of which desirability analysis tells us so,
|
||||||
|
we eliminate.
|
||||||
|
The we shift our window and continue.
|
||||||
46
doc/ego/cs/cs5
Normal file
46
doc/ego/cs/cs5
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
.NH 2
|
||||||
|
Source files of CS
|
||||||
|
.PP
|
||||||
|
The sources of CS are in the following files and packages:
|
||||||
|
.IP cs.h 14
|
||||||
|
declarations of global variables and data structures
|
||||||
|
.IP cs.c
|
||||||
|
the routine main;
|
||||||
|
a driving routine to process
|
||||||
|
the basic blocks in the right order
|
||||||
|
.IP vnm
|
||||||
|
implements a procedure that performs
|
||||||
|
the value numbering on one basic block
|
||||||
|
.IP eliminate
|
||||||
|
implements a procedure that does the
|
||||||
|
transformations, if desirable
|
||||||
|
.IP avail
|
||||||
|
implements a procedure that manipulates the list of available expressions
|
||||||
|
.IP entity
|
||||||
|
implements a procedure that manipulates the set of entities
|
||||||
|
.IP getentity
|
||||||
|
implements a procedure that extracts the
|
||||||
|
pseudo symboltable information from EM-instructions;
|
||||||
|
uses a small table
|
||||||
|
.IP kill
|
||||||
|
implements several routines that find the entities
|
||||||
|
that might be changed by EM-instructions
|
||||||
|
and kill them
|
||||||
|
.IP partition
|
||||||
|
implements several routines that partition the huge set
|
||||||
|
of EM-instructions into more or less manageable,
|
||||||
|
more or less logical chunks
|
||||||
|
.IP profit
|
||||||
|
implements a procedure that decides whether it
|
||||||
|
is advantageous to eliminate an expression;
|
||||||
|
also removes expressions with side-effects
|
||||||
|
.IP stack
|
||||||
|
implements the fake-stack and operations on it
|
||||||
|
.IP alloc
|
||||||
|
implements several allocation routines
|
||||||
|
.IP aux
|
||||||
|
implements several auxiliary routines
|
||||||
|
.IP debug
|
||||||
|
implements several routines to provide debugging
|
||||||
|
and verbose output
|
||||||
|
.LP
|
||||||
5
doc/ego/ic/.distr
Normal file
5
doc/ego/ic/.distr
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
ic1
|
||||||
|
ic2
|
||||||
|
ic3
|
||||||
|
ic4
|
||||||
|
ic5
|
||||||
57
doc/ego/ic/ic1
Normal file
57
doc/ego/ic/ic1
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
.bp
|
||||||
|
.NH
|
||||||
|
The Intermediate Code and the IC phase
|
||||||
|
.PP
|
||||||
|
In this chapter the intermediate code of the EM global optimizer
|
||||||
|
will be defined.
|
||||||
|
The 'Intermediate Code construction' phase (IC),
|
||||||
|
which builds the initial intermediate code from
|
||||||
|
EM Compact Assembly Language,
|
||||||
|
will be described.
|
||||||
|
.NH 2
|
||||||
|
Introduction
|
||||||
|
.PP
|
||||||
|
The EM global optimizer is a multi pass program,
|
||||||
|
hence there is a need for an intermediate code.
|
||||||
|
Usually, programs in the Amsterdam Compiler Kit use the
|
||||||
|
Compact Assembly Language format
|
||||||
|
.[~[
|
||||||
|
keizer architecture
|
||||||
|
.], section 11.2]
|
||||||
|
for this purpose.
|
||||||
|
Although this code has some convenient features,
|
||||||
|
such as being compact,
|
||||||
|
it is quite unsuitable in our case,
|
||||||
|
because of a number of reasons.
|
||||||
|
At first, the code lacks global information
|
||||||
|
about whole procedures or whole basic blocks.
|
||||||
|
Second, it uses identifiers ('names') to bind
|
||||||
|
defining and applied occurrences of
|
||||||
|
procedures, data labels and instruction labels.
|
||||||
|
Although this is usual in high level programming
|
||||||
|
languages, it is awkward in an intermediate code
|
||||||
|
that must be read many times.
|
||||||
|
Each pass of the optimizer would have
|
||||||
|
to incorporate an identifier look-up mechanism
|
||||||
|
to associate a defining occurrence with each
|
||||||
|
applied occurrence of an identifier.
|
||||||
|
Finally, EM programs are used to declare blocks of bytes,
|
||||||
|
rather than variables. A 'hol 6' instruction may be used to
|
||||||
|
declare three 2-byte variables.
|
||||||
|
Clearly, the optimizer wants to deal with variables, and
|
||||||
|
not with rows of bytes.
|
||||||
|
.PP
|
||||||
|
To overcome these problems, we have developed a new
|
||||||
|
intermediate code.
|
||||||
|
This code does not merely consist of the EM instructions,
|
||||||
|
but also contains global information in the
|
||||||
|
form of tables and graphs.
|
||||||
|
Before describing the intermediate code we will
|
||||||
|
first leap aside to outline
|
||||||
|
the problems one generally encounters
|
||||||
|
when trying to store complex data structures such as
|
||||||
|
graphs outside the program, i.e. in a file.
|
||||||
|
We trust this will enhance the
|
||||||
|
comprehensibility of the
|
||||||
|
intermediate code definition and the design and implementation
|
||||||
|
of the IC phase.
|
||||||
150
doc/ego/ic/ic2
Normal file
150
doc/ego/ic/ic2
Normal file
@ -0,0 +1,150 @@
|
|||||||
|
.NH 2
|
||||||
|
Representation of complex data structures in a sequential file
|
||||||
|
.PP
|
||||||
|
Most programmers are quite used to deal with
|
||||||
|
complex data structures, such as
|
||||||
|
arrays, graphs and trees.
|
||||||
|
There are some particular problems that occur
|
||||||
|
when storing such a data structure
|
||||||
|
in a sequential file.
|
||||||
|
We call data that is kept in
|
||||||
|
main memory
|
||||||
|
.UL internal
|
||||||
|
,as opposed to
|
||||||
|
.UL external
|
||||||
|
data
|
||||||
|
that is kept in a file outside the program.
|
||||||
|
.sp
|
||||||
|
We assume a simple data structure of a
|
||||||
|
scalar type (integer, floating point number)
|
||||||
|
has some known external representation.
|
||||||
|
An
|
||||||
|
.UL array
|
||||||
|
having elements of a scalar type can be represented
|
||||||
|
externally easily, by successively
|
||||||
|
representing its elements.
|
||||||
|
The external representation may be preceded by a
|
||||||
|
number, giving the length of the array.
|
||||||
|
Now, consider a linear, singly linked list,
|
||||||
|
the elements of which look like:
|
||||||
|
.DS
|
||||||
|
record
|
||||||
|
data: scalar_type;
|
||||||
|
next: pointer_type;
|
||||||
|
end;
|
||||||
|
.DE
|
||||||
|
It is significant to note that the "next"
|
||||||
|
fields of the elements only have a meaning within
|
||||||
|
main memory.
|
||||||
|
The field contains the address of some location in
|
||||||
|
main memory.
|
||||||
|
If a list element is written to a file in
|
||||||
|
some program,
|
||||||
|
and read by another program,
|
||||||
|
the element will be allocated at a different
|
||||||
|
address in main memory.
|
||||||
|
Hence this address value is completely
|
||||||
|
useless outside the program.
|
||||||
|
.sp
|
||||||
|
One may represent the list by ignoring these "next" fields
|
||||||
|
and storing the data items in the order they are linked.
|
||||||
|
The "next" fields are represented \fIimplicitly\fR.
|
||||||
|
When the file is read again,
|
||||||
|
the same list can be reconstructed.
|
||||||
|
In order to know where the external representation of the
|
||||||
|
list ends,
|
||||||
|
it may be useful to put the length of
|
||||||
|
the list in front of it.
|
||||||
|
.sp
|
||||||
|
Note that arrays and linear lists have the
|
||||||
|
same external representation.
|
||||||
|
.PP
|
||||||
|
A doubly linked, linear list,
|
||||||
|
with elements of the type:
|
||||||
|
.DS
|
||||||
|
record
|
||||||
|
data: scalar_type;
|
||||||
|
next,
|
||||||
|
previous: pointer_type;
|
||||||
|
end
|
||||||
|
.DE
|
||||||
|
can be represented in precisely the same way.
|
||||||
|
Both the "next" and the "previous" fields are represented
|
||||||
|
implicitly.
|
||||||
|
.PP
|
||||||
|
Next, consider a binary tree,
|
||||||
|
the nodes of which have type:
|
||||||
|
.DS
|
||||||
|
record
|
||||||
|
data: scalar_type;
|
||||||
|
left,
|
||||||
|
right: pointer_type;
|
||||||
|
end
|
||||||
|
.DE
|
||||||
|
Such a tree can be represented sequentially,
|
||||||
|
by storing its nodes in some fixed order, e.g. prefix order.
|
||||||
|
A special null data item may be used to
|
||||||
|
denote a missing left or right son.
|
||||||
|
For example, let the scalar type be integer,
|
||||||
|
and let the null item be 0.
|
||||||
|
Then the tree of fig. 3.1(a)
|
||||||
|
can be represented as in fig. 3.1(b).
|
||||||
|
.DS
|
||||||
|
.ft 5
|
||||||
|
4
|
||||||
|
/ \e
|
||||||
|
9 12
|
||||||
|
/ \e / \e
|
||||||
|
12 3 4 6
|
||||||
|
/ \e \e /
|
||||||
|
8 1 5 1
|
||||||
|
.ft R
|
||||||
|
|
||||||
|
Fig. 3.1(a) A binary tree
|
||||||
|
|
||||||
|
|
||||||
|
.ft 5
|
||||||
|
4 9 12 0 0 3 8 0 0 1 0 0 12 4 0 5 0 0 6 1 0 0 0
|
||||||
|
.ft R
|
||||||
|
|
||||||
|
Fig. 3.1(b) Its sequential representation
|
||||||
|
.DE
|
||||||
|
We are still able to represent the pointer fields ("left"
|
||||||
|
and "right") implicitly.
|
||||||
|
.PP
|
||||||
|
Finally, consider a general
|
||||||
|
.UL graph
|
||||||
|
, where each node has a "data" field and
|
||||||
|
pointer fields,
|
||||||
|
with no restriction on where they may point to.
|
||||||
|
Now we're at the end of our tale.
|
||||||
|
There is no way to represent the pointers implicitly,
|
||||||
|
like we did with lists and trees.
|
||||||
|
In order to represent them explicitly,
|
||||||
|
we use the following scheme.
|
||||||
|
Every node gets an extra field,
|
||||||
|
containing some unique number that identifies the node.
|
||||||
|
We call this number its
|
||||||
|
.UL id.
|
||||||
|
A pointer is represented externally as the id of the node
|
||||||
|
it points to.
|
||||||
|
When reading the file we use a table that maps
|
||||||
|
an id to the address of its node.
|
||||||
|
In general this table will not be completely filled in
|
||||||
|
until we have read the entire external representation of
|
||||||
|
the graph and allocated internal memory locations for
|
||||||
|
every node.
|
||||||
|
Hence we cannot reconstruct the graph in one scan.
|
||||||
|
That is, there may be some pointers from node A to B,
|
||||||
|
where B is placed after A in the sequential file than A.
|
||||||
|
When we read the node of A we cannot map the id of B
|
||||||
|
to the address of node B,
|
||||||
|
as we have not yet allocated node B.
|
||||||
|
We can overcome this problem if the size
|
||||||
|
of every node is known in advance.
|
||||||
|
In this case we can allocate memory for a node
|
||||||
|
on first reference.
|
||||||
|
Else, the mapping from id to pointer
|
||||||
|
cannot be done while reading nodes.
|
||||||
|
The mapping can be done either in an extra scan
|
||||||
|
or at every reference to the node.
|
||||||
431
doc/ego/ic/ic3
Normal file
431
doc/ego/ic/ic3
Normal file
@ -0,0 +1,431 @@
|
|||||||
|
.NH 2
|
||||||
|
Definition of the intermediate code
|
||||||
|
.PP
|
||||||
|
The intermediate code of the optimizer consists
|
||||||
|
of several components:
|
||||||
|
.IP -
|
||||||
|
the object table
|
||||||
|
.IP -
|
||||||
|
the procedure table
|
||||||
|
.IP -
|
||||||
|
the em code
|
||||||
|
.IP -
|
||||||
|
the control flow graphs
|
||||||
|
.IP -
|
||||||
|
the loop table
|
||||||
|
.LP -
|
||||||
|
.PP
|
||||||
|
These components are described in
|
||||||
|
the next sections.
|
||||||
|
The syntactic structure of every component
|
||||||
|
is described by a set of context free syntax rules,
|
||||||
|
with the following conventions:
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
x a non-terminal symbol
|
||||||
|
A a terminal symbol (in capitals)
|
||||||
|
x: a b c; a grammar rule
|
||||||
|
a | b a or b
|
||||||
|
(a)+ 1 or more occurrences of a
|
||||||
|
{a} 0 or more occurrences of a
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
.NH 3
|
||||||
|
The object table
|
||||||
|
.PP
|
||||||
|
EM programs declare blocks of bytes rather than (global) variables.
|
||||||
|
A typical program may declare 'HOL 7780'
|
||||||
|
to allocate space for 8 I/O buffers,
|
||||||
|
2 large arrays and 10 scalar variables.
|
||||||
|
The optimizer wants to deal with
|
||||||
|
.UL objects
|
||||||
|
like variables, buffers and arrays
|
||||||
|
and certainly not with huge numbers of bytes.
|
||||||
|
Therefore the intermediate code contains information
|
||||||
|
about which global objects are used.
|
||||||
|
This information can be obtained from an EM program
|
||||||
|
by just looking at the operands of instruction
|
||||||
|
such as LOE, LAE, LDE, STE, SDE, INE, DEE and ZRE.
|
||||||
|
.PP
|
||||||
|
The object table consists of a list of
|
||||||
|
.UL datablock
|
||||||
|
entries.
|
||||||
|
Each such entry represents a declaration like HOL, BSS,
|
||||||
|
CON or ROM.
|
||||||
|
There are five kinds of datablock entries.
|
||||||
|
The fifth kind,
|
||||||
|
UNKNOWN, denotes a declaration in a
|
||||||
|
separately compiled file that is not made
|
||||||
|
available to the optimizer.
|
||||||
|
Each datablock entry contains the type of the block,
|
||||||
|
its size, and a description of the objects that
|
||||||
|
belong to it.
|
||||||
|
If it is a rom,
|
||||||
|
it also contains a list of values given
|
||||||
|
as arguments to the rom instruction,
|
||||||
|
provided that this list contains only integer numbers.
|
||||||
|
An object has an offset (within its datablock)
|
||||||
|
and a size.
|
||||||
|
The size need not always be determinable.
|
||||||
|
Both datablock and object contain a unique
|
||||||
|
identifying number
|
||||||
|
(see previous section for their use).
|
||||||
|
.DS
|
||||||
|
.UL syntax
|
||||||
|
.TS
|
||||||
|
lw(1i) l l.
|
||||||
|
object_table:
|
||||||
|
{datablock} ;
|
||||||
|
datablock:
|
||||||
|
D_ID -- unique identifying number
|
||||||
|
PSEUDO -- one of ROM,CON,BSS,HOL,UNKNOWN
|
||||||
|
SIZE -- # bytes declared
|
||||||
|
FLAGS
|
||||||
|
{value} -- contents of rom
|
||||||
|
{object} ; -- objects of the datablock
|
||||||
|
object:
|
||||||
|
O_ID -- unique identifying number
|
||||||
|
OFFSET -- offset within the datablock
|
||||||
|
SIZE ; -- size of the object in bytes
|
||||||
|
value:
|
||||||
|
argument ;
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
A data block has only one flag: "external", indicating
|
||||||
|
whether the data label is externally visible.
|
||||||
|
The syntax for "argument" will be given later on
|
||||||
|
(see em_text).
|
||||||
|
.NH 3
|
||||||
|
The procedure table
|
||||||
|
.PP
|
||||||
|
The procedure table contains global information
|
||||||
|
about all procedures that are made available
|
||||||
|
to the optimizer
|
||||||
|
and that are needed by the EM program.
|
||||||
|
(Library units may not be needed, see section 3.5).
|
||||||
|
The table has one entry for
|
||||||
|
every procedure.
|
||||||
|
.DS
|
||||||
|
.UL syntax
|
||||||
|
.TS
|
||||||
|
lw(1i) l l.
|
||||||
|
procedure_table:
|
||||||
|
{procedure}
|
||||||
|
procedure:
|
||||||
|
P_ID -- unique identifying number
|
||||||
|
#LABELS -- number of instruction labels
|
||||||
|
#LOCALS -- number of bytes for locals
|
||||||
|
#FORMALS -- number of bytes for formals
|
||||||
|
FLAGS -- flag bits
|
||||||
|
calling -- procedures called by this one
|
||||||
|
change -- info about global variables changed
|
||||||
|
use ; -- info about global variables used
|
||||||
|
calling:
|
||||||
|
{P_ID} ; -- procedures called
|
||||||
|
change:
|
||||||
|
ext -- external variables changed
|
||||||
|
FLAGS ;
|
||||||
|
use:
|
||||||
|
FLAGS ;
|
||||||
|
ext:
|
||||||
|
{O_ID} ; -- a set of objects
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
.PP
|
||||||
|
The number of bytes of formal parameters accessed by
|
||||||
|
a procedure is determined by the front ends and
|
||||||
|
passed via a message (parameter message) to the optimizer.
|
||||||
|
If the front end is not able to determine this number
|
||||||
|
(e.g. the parameter may be an array of dynamic size or
|
||||||
|
the procedure may have a variable number of arguments) the attribute
|
||||||
|
contains the value 'UNKNOWN_SIZE'.
|
||||||
|
.sp 0
|
||||||
|
A procedure has the following flags:
|
||||||
|
.IP -
|
||||||
|
external: true if the proc. is externally visible
|
||||||
|
.IP -
|
||||||
|
bodyseen: true if its code is available as EM text
|
||||||
|
.IP -
|
||||||
|
calunknown: true if it calls a procedure that has its bodyseen
|
||||||
|
flag not set
|
||||||
|
.IP -
|
||||||
|
environ: true if it uses or changes a (non-global) variable in
|
||||||
|
a lexically enclosing procedure
|
||||||
|
.IP -
|
||||||
|
lpi: true if is used as operand of an lpi instruction, so
|
||||||
|
it may be called indirect
|
||||||
|
.LP
|
||||||
|
The change and use attributes both have one flag: "indirect",
|
||||||
|
indicating whether the procedure does a 'use indirect'
|
||||||
|
or a 'store indirect' (indirect means through a pointer).
|
||||||
|
.NH 3
|
||||||
|
The EM text
|
||||||
|
.PP
|
||||||
|
The EM text contains the EM instructions.
|
||||||
|
Every EM instruction has an operation code (opcode)
|
||||||
|
and 0 or 1 operands.
|
||||||
|
EM pseudo instructions can have more than
|
||||||
|
1 operand.
|
||||||
|
The opcode is just a small (8 bit) integer.
|
||||||
|
.sp
|
||||||
|
There are several kinds of operands, which we will
|
||||||
|
refer to as
|
||||||
|
.UL types.
|
||||||
|
Many EM instructions can have more than one type of operand.
|
||||||
|
The types and their encodings in Compact Assembly Language
|
||||||
|
are discussed extensively in.
|
||||||
|
.[~[
|
||||||
|
keizer architecture
|
||||||
|
.], section 11.2]
|
||||||
|
Of special interest is the way numeric values
|
||||||
|
are represented.
|
||||||
|
Of prime importance is the machine independency of
|
||||||
|
the representation.
|
||||||
|
Ultimately, one could store every integer
|
||||||
|
just as a string of the characters '0' to '9'.
|
||||||
|
As doing arithmetic on strings is awkward,
|
||||||
|
Compact Assembly Language allows several alternatives.
|
||||||
|
The main idea is to look at the value of the integer.
|
||||||
|
Integers that fit in 16, 32 or 64 bits are
|
||||||
|
represented as a row of resp. 2, 4 and 8 bytes,
|
||||||
|
preceded by an indication of how many bytes are used.
|
||||||
|
Longer integers are represented as strings;
|
||||||
|
this is only allowed within pseudo instructions, however.
|
||||||
|
This concept works very well for target machines
|
||||||
|
with reasonable word sizes.
|
||||||
|
At present, most ACK software cannot be used for word sizes
|
||||||
|
higher than 32 bits,
|
||||||
|
although the handles for using larger word sizes are
|
||||||
|
present in the design of the EM code.
|
||||||
|
In the intermediate code we essentially use the
|
||||||
|
same ideas.
|
||||||
|
We allow three representations of integers.
|
||||||
|
.IP -
|
||||||
|
integers that fit in a short are represented as a short
|
||||||
|
.IP -
|
||||||
|
integers that fit in a long but not in a short are represented
|
||||||
|
as longs
|
||||||
|
.IP -
|
||||||
|
all remaining integers are represented as strings
|
||||||
|
(only allowed in pseudos).
|
||||||
|
.LP
|
||||||
|
The terms short and long are defined in
|
||||||
|
.[~[
|
||||||
|
ritchie reference manual programming language
|
||||||
|
.], section 4]
|
||||||
|
and depend only on the source machine
|
||||||
|
(i.e. the machine on which ACK runs),
|
||||||
|
not on the target machines.
|
||||||
|
For historical reasons a long will often be called an
|
||||||
|
.UL offset.
|
||||||
|
.PP
|
||||||
|
Operands can also be instruction labels,
|
||||||
|
objects or procedures.
|
||||||
|
Instruction labels are denoted by a
|
||||||
|
.UL label
|
||||||
|
.UL identifier,
|
||||||
|
which can be distinguished from a normal identifier.
|
||||||
|
.sp
|
||||||
|
The operand of a pseudo instruction can be a list of
|
||||||
|
.UL arguments.
|
||||||
|
Arguments can have the same type as operands, except
|
||||||
|
for the type short, which is not used for arguments.
|
||||||
|
Furthermore, an argument can be a string or
|
||||||
|
a string representation of a signed integer, unsigned integer
|
||||||
|
or floating point number.
|
||||||
|
If the number of arguments is not fully determined by
|
||||||
|
the pseudo instruction (e.g. a ROM pseudo can have any number
|
||||||
|
of arguments), then the list is terminated by a special
|
||||||
|
argument of type CEND.
|
||||||
|
.DS
|
||||||
|
.UL syntax
|
||||||
|
.TS
|
||||||
|
lw(1i) l l.
|
||||||
|
em_text:
|
||||||
|
{line} ;
|
||||||
|
line:
|
||||||
|
INSTR -- opcode
|
||||||
|
OPTYPE -- operand type
|
||||||
|
operand ;
|
||||||
|
operand:
|
||||||
|
empty | -- OPTYPE = NO
|
||||||
|
SHORT | -- OPTYPE = SHORT
|
||||||
|
OFFSET | -- OPTYPE = OFFSET
|
||||||
|
LAB_ID | -- OPTYPE = INSTRLAB
|
||||||
|
O_ID | -- OPTYPE = OBJECT
|
||||||
|
P_ID | -- OPTYPE = PROCEDURE
|
||||||
|
{argument} ; -- OPTYPE = LIST
|
||||||
|
argument:
|
||||||
|
ARGTYPE
|
||||||
|
arg ;
|
||||||
|
arg:
|
||||||
|
empty | -- ARGTYPE = CEND
|
||||||
|
OFFSET |
|
||||||
|
LAB_ID |
|
||||||
|
O_ID |
|
||||||
|
P_ID |
|
||||||
|
string | -- ARGTYPE = STRING
|
||||||
|
const ; -- ARGTYPE = ICON,UCON or FCON
|
||||||
|
string:
|
||||||
|
LENGTH -- number of characters
|
||||||
|
{CHARACTER} ;
|
||||||
|
const:
|
||||||
|
SIZE -- number of bytes
|
||||||
|
string ; -- string representation of (un)signed
|
||||||
|
-- or floating point constant
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
.NH 3
|
||||||
|
The control flow graphs
|
||||||
|
.PP
|
||||||
|
Each procedure can be divided
|
||||||
|
into a number of basic blocks.
|
||||||
|
A basic block is a piece of code with
|
||||||
|
no jumps in, except at the beginning,
|
||||||
|
and no jumps out, except at the end.
|
||||||
|
.PP
|
||||||
|
Every basic block has a set of
|
||||||
|
.UL successors,
|
||||||
|
which are basic blocks that can follow it immediately in
|
||||||
|
the dynamic execution sequence.
|
||||||
|
The
|
||||||
|
.UL predecessors
|
||||||
|
are the basic blocks of which this one
|
||||||
|
is a successor.
|
||||||
|
The successor and predecessor attributes
|
||||||
|
of all basic blocks of a single procedure
|
||||||
|
are said to form the
|
||||||
|
.UL control
|
||||||
|
.UL flow
|
||||||
|
.UL graph
|
||||||
|
of that procedure.
|
||||||
|
.PP
|
||||||
|
Another important attribute is the
|
||||||
|
.UL immediate
|
||||||
|
.UL dominator.
|
||||||
|
A basic block B dominates a block C if
|
||||||
|
every path in the graph from the procedure entry block
|
||||||
|
to C goes through B.
|
||||||
|
The immediate dominator of C is the closest dominator
|
||||||
|
of C on any path from the entry block.
|
||||||
|
(Note that the dominator relation is transitive,
|
||||||
|
so the immediate dominator is well defined.)
|
||||||
|
.PP
|
||||||
|
A basic block also has an attribute containing
|
||||||
|
the identifiers of every
|
||||||
|
.UL loop
|
||||||
|
that the block belongs to (see next section for loops).
|
||||||
|
.DS
|
||||||
|
.UL syntax
|
||||||
|
.TS
|
||||||
|
lw(1i) l l.
|
||||||
|
control_flow_graph:
|
||||||
|
{basic_block} ;
|
||||||
|
basic_block:
|
||||||
|
B_ID -- unique identifying number
|
||||||
|
#INSTR -- number of EM instructions
|
||||||
|
succ
|
||||||
|
pred
|
||||||
|
idom -- immediate dominator
|
||||||
|
loops -- set of loops
|
||||||
|
FLAGS ; -- flag bits
|
||||||
|
succ:
|
||||||
|
{B_ID} ;
|
||||||
|
pred:
|
||||||
|
{B_ID} ;
|
||||||
|
idom:
|
||||||
|
B_ID ;
|
||||||
|
loops:
|
||||||
|
{LP_ID} ;
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
The flag bits can have the values 'firm' and 'strong',
|
||||||
|
which are explained below.
|
||||||
|
.NH 3
|
||||||
|
The loop tables
|
||||||
|
.PP
|
||||||
|
Every procedure has an associated
|
||||||
|
.UL loop
|
||||||
|
.UL table
|
||||||
|
containing information about all the loops
|
||||||
|
in the procedure.
|
||||||
|
Loops can be detected by a close inspection of
|
||||||
|
the control flow graph.
|
||||||
|
The main idea is to look for two basic blocks,
|
||||||
|
B and C, for which the following holds:
|
||||||
|
.IP -
|
||||||
|
B is a successor of C
|
||||||
|
.IP -
|
||||||
|
B is a dominator of C
|
||||||
|
.LP
|
||||||
|
B is called the loop
|
||||||
|
.UL entry
|
||||||
|
and C is called the loop
|
||||||
|
.UL end.
|
||||||
|
Intuitively, C contains a jump backwards to
|
||||||
|
the beginning of the loop (B).
|
||||||
|
.PP
|
||||||
|
A loop L1 is said to be
|
||||||
|
.UL nested
|
||||||
|
within loop L2 if all basic blocks of L1
|
||||||
|
are also part of L2.
|
||||||
|
It is important to note that loops could
|
||||||
|
originally be written as a well structured for -or
|
||||||
|
while loop or as a messy goto loop.
|
||||||
|
Hence loops may partly overlap without one
|
||||||
|
being nested inside the other.
|
||||||
|
The
|
||||||
|
.UL nesting
|
||||||
|
.UL level
|
||||||
|
of a loop is the number of loops in
|
||||||
|
which it is nested (so it is 0 for
|
||||||
|
an outermost loop).
|
||||||
|
The details of loop detection will be discussed later.
|
||||||
|
.PP
|
||||||
|
It is often desirable to know whether a
|
||||||
|
basic block gets executed during every iteration
|
||||||
|
of a loop.
|
||||||
|
This leads to the following definitions:
|
||||||
|
.IP -
|
||||||
|
A basic block B of a loop L is said to be a \fIfirm\fR block
|
||||||
|
of L if B is executed on all successive iterations of L,
|
||||||
|
with the only possible exception of the last iteration.
|
||||||
|
.IP -
|
||||||
|
A basic block B of a loop L is said to be a \fIstrong\fR block
|
||||||
|
of L if B is executed on all successive iterations of L.
|
||||||
|
.LP
|
||||||
|
Note that a strong block is also a firm block.
|
||||||
|
If a block is part of a conditional statement, it is neither
|
||||||
|
strong nor firm, as it may be skipped during some iterations
|
||||||
|
(see Fig. 3.2).
|
||||||
|
.DS
|
||||||
|
loop
|
||||||
|
if cond1 then
|
||||||
|
... \kx-- this code will not
|
||||||
|
\h'|\nxu'-- result in a firm or strong block
|
||||||
|
end if;
|
||||||
|
... -- strong (always executed)
|
||||||
|
exit when cond2;
|
||||||
|
... \kx-- firm (not executed on last iteration).
|
||||||
|
end loop;
|
||||||
|
|
||||||
|
Fig. 3.2 Example of firm and strong block
|
||||||
|
.DE
|
||||||
|
.DS
|
||||||
|
.UL syntax
|
||||||
|
.TS
|
||||||
|
lw(1i) l l.
|
||||||
|
looptable:
|
||||||
|
{loop} ;
|
||||||
|
loop:
|
||||||
|
LP_ID -- unique identifying number
|
||||||
|
LEVEL -- loop nesting level
|
||||||
|
entry -- loop entry block
|
||||||
|
end ;
|
||||||
|
entry:
|
||||||
|
B_ID ;
|
||||||
|
end:
|
||||||
|
B_ID ;
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
83
doc/ego/ic/ic4
Normal file
83
doc/ego/ic/ic4
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
.NH 2
|
||||||
|
External representation of the intermediate code
|
||||||
|
.PP
|
||||||
|
The syntax of the intermediate code was given
|
||||||
|
in the previous section.
|
||||||
|
In this section we will make some remarks about
|
||||||
|
the representation of the code in sequential files.
|
||||||
|
.sp
|
||||||
|
We use sequential files in order to avoid
|
||||||
|
the bookkeeping of complex file indices.
|
||||||
|
As a consequence of this decision
|
||||||
|
we can't store all components
|
||||||
|
of the intermediate code
|
||||||
|
in one file.
|
||||||
|
If a phase wishes to change some attribute
|
||||||
|
of a procedure,
|
||||||
|
or wants to add or delete entire procedures
|
||||||
|
(inline substitution may do the latter),
|
||||||
|
the procedure table will only be fully updated
|
||||||
|
after the entire EM text has been scanned.
|
||||||
|
Yet, the next phase undoubtedly wants
|
||||||
|
to read the procedure table before it
|
||||||
|
starts working on the EM text.
|
||||||
|
Hence there is an ordering problem, which
|
||||||
|
can be solved easily by putting the
|
||||||
|
procedure table in a separate file.
|
||||||
|
Similarly, the data block table is kept
|
||||||
|
in a file of its own.
|
||||||
|
.PP
|
||||||
|
The control flow graphs (CFGs) could be mixed
|
||||||
|
with the EM text.
|
||||||
|
Rather, we have chosen to put them
|
||||||
|
in a separate file too.
|
||||||
|
The control flow graph file should be regarded as a
|
||||||
|
file that imposes some structure on the EM-text file,
|
||||||
|
just as an overhead sheet containing a picture
|
||||||
|
of a Flow Chart may be put on an overhead sheet
|
||||||
|
containing statements.
|
||||||
|
The loop tables are also put in the CFG file.
|
||||||
|
A loop imposes an extra structure on the
|
||||||
|
CFGs and hence on the EM text.
|
||||||
|
So there are four files:
|
||||||
|
.IP -
|
||||||
|
the EM-text file
|
||||||
|
.IP -
|
||||||
|
the procedure table file
|
||||||
|
.IP -
|
||||||
|
the object table file
|
||||||
|
.IP -
|
||||||
|
the CFG and loop tables file
|
||||||
|
.LP
|
||||||
|
Every table is preceded by its length, in order to
|
||||||
|
tell where it ends.
|
||||||
|
The CFG file also contains the number of instructions of
|
||||||
|
every basic block,
|
||||||
|
indicating which part of the EM text belongs
|
||||||
|
to that block.
|
||||||
|
.DS
|
||||||
|
.UL syntax
|
||||||
|
.TS
|
||||||
|
lw(1i) l l.
|
||||||
|
intermediate_code:
|
||||||
|
object_table_file
|
||||||
|
proctable_file
|
||||||
|
em_text_file
|
||||||
|
cfg_file ;
|
||||||
|
object_table_file:
|
||||||
|
LENGTH -- number of objects
|
||||||
|
object_table ;
|
||||||
|
proctable_file:
|
||||||
|
LENGTH -- number of procedures
|
||||||
|
procedure_table ;
|
||||||
|
em_text_file:
|
||||||
|
em_text ;
|
||||||
|
cfg_file:
|
||||||
|
{per_proc} ; -- one for every procedure
|
||||||
|
per_proc:
|
||||||
|
BLENGTH -- number of basic blocks
|
||||||
|
LLENGTH -- number of loops
|
||||||
|
control_flow_graph
|
||||||
|
looptable ;
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
166
doc/ego/ic/ic5
Normal file
166
doc/ego/ic/ic5
Normal file
@ -0,0 +1,166 @@
|
|||||||
|
.NH 2
|
||||||
|
The Intermediate Code construction phase
|
||||||
|
.PP
|
||||||
|
The first phase of the global optimizer,
|
||||||
|
called
|
||||||
|
.UL IC,
|
||||||
|
constructs a major part of the intermediate code.
|
||||||
|
To be specific, it produces:
|
||||||
|
.IP -
|
||||||
|
the EM text
|
||||||
|
.IP -
|
||||||
|
the object table
|
||||||
|
.IP -
|
||||||
|
part of the procedure table
|
||||||
|
.LP
|
||||||
|
The calling, change and use attributes of a procedure
|
||||||
|
and all its flags except the external and bodyseen flags
|
||||||
|
are computed by the next phase (Control Flow phase).
|
||||||
|
.PP
|
||||||
|
As explained before,
|
||||||
|
the intermediate code does not contain
|
||||||
|
any names of variables or procedures.
|
||||||
|
The normal identifiers are replaced by identifying
|
||||||
|
numbers.
|
||||||
|
Yet, the output of the global optimizer must
|
||||||
|
contain normal identifiers, as this
|
||||||
|
output is in Compact Assembly Language format.
|
||||||
|
We certainly want all externally visible names
|
||||||
|
to be the same in the input as in the output,
|
||||||
|
because the optimized EM module may be a library unit,
|
||||||
|
used by other modules.
|
||||||
|
IC dumps the names of all procedures and data labels
|
||||||
|
on two files:
|
||||||
|
.IP -
|
||||||
|
the procedure dump file, containing tuples (P_ID, procedure name)
|
||||||
|
.IP -
|
||||||
|
the data dump file, containing tuples (D_ID, data label name)
|
||||||
|
.LP
|
||||||
|
The names of instruction labels are not dumped,
|
||||||
|
as they are not visible outside the procedure
|
||||||
|
in which they are defined.
|
||||||
|
.PP
|
||||||
|
The input to IC consists of one or more files.
|
||||||
|
Each file is either an EM module in Compact Assembly Language
|
||||||
|
format, or a Unix archive file (library) containing such modules.
|
||||||
|
IC only extracts those modules from a library that are
|
||||||
|
needed somehow, just as a linker does.
|
||||||
|
It is advisable to present as much code
|
||||||
|
of the EM program as possible to the optimizer,
|
||||||
|
although it is not required to present the whole program.
|
||||||
|
If a procedure is called somewhere in the EM text,
|
||||||
|
but its body (text) is not included in the input,
|
||||||
|
its bodyseen flag in the procedure table will still
|
||||||
|
be off.
|
||||||
|
Whenever such a procedure is called,
|
||||||
|
we assume the worst case for everything;
|
||||||
|
it will change and use all variables it has access to,
|
||||||
|
it will call every procedure etc.
|
||||||
|
.sp
|
||||||
|
Similarly, if a data label is used
|
||||||
|
but not defined, the PSEUDO attribute in its data block
|
||||||
|
will be set to UNKNOWN.
|
||||||
|
.NH 3
|
||||||
|
Implementation
|
||||||
|
.PP
|
||||||
|
Part of the code for the EM Peephole Optimizer
|
||||||
|
.[
|
||||||
|
staveren peephole toplass
|
||||||
|
.]
|
||||||
|
has been used for IC.
|
||||||
|
Especially the routines that read and unravel
|
||||||
|
Compact Assembly Language and the identifier
|
||||||
|
lookup mechanism have been used.
|
||||||
|
New code was added to recognize objects,
|
||||||
|
build the object and procedure tables and to
|
||||||
|
output the intermediate code.
|
||||||
|
.PP
|
||||||
|
IC uses singly linked linear lists for both the
|
||||||
|
procedure and object table.
|
||||||
|
Hence there are no limits on the size of such
|
||||||
|
a table (except for the trivial fact that it must fit
|
||||||
|
in main memory).
|
||||||
|
Both tables are outputted after all EM code has
|
||||||
|
been processed.
|
||||||
|
IC reads the EM text of one entire procedure
|
||||||
|
at a time,
|
||||||
|
processes it and appends the modified code to
|
||||||
|
the EM text file.
|
||||||
|
EM code is represented internally as a doubly linked linear
|
||||||
|
list of EM instructions.
|
||||||
|
.PP
|
||||||
|
Objects are recognized by looking at the operands
|
||||||
|
of instructions that reference global data.
|
||||||
|
If we come across the instructions:
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
LDE X+6 -- Load Double External
|
||||||
|
LAE X+20 -- Load Address External
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
we conclude that the data block
|
||||||
|
preceded by the data label X contains an object
|
||||||
|
at offset 6 of size twice the word size,
|
||||||
|
and an object at offset 20 of unknown size.
|
||||||
|
.sp
|
||||||
|
A data block entry of the object table is allocated
|
||||||
|
at the first reference to a data label.
|
||||||
|
If this reference is a defining occurrence
|
||||||
|
or a INA pseudo instruction,
|
||||||
|
the label is not externally visible
|
||||||
|
.[~[
|
||||||
|
keizer architecture
|
||||||
|
.], section 11.1.4.3]
|
||||||
|
In this case, the external flag of the data block
|
||||||
|
is turned off.
|
||||||
|
If the first reference is an applied occurrence
|
||||||
|
or a EXA pseudo instruction, the flag is set.
|
||||||
|
We record this information, because the
|
||||||
|
optimizer may change the order of defining and
|
||||||
|
applied occurrences.
|
||||||
|
The INA and EXA pseudos are removed from the EM text.
|
||||||
|
They may be regenerated by the last phase
|
||||||
|
of the optimizer.
|
||||||
|
.sp
|
||||||
|
Similar rules hold for the procedure table
|
||||||
|
and the INP and EXP pseudos.
|
||||||
|
.NH 3
|
||||||
|
Source files of IC
|
||||||
|
.PP
|
||||||
|
The source files of IC consist
|
||||||
|
of the files ic.c, ic.h and several packages.
|
||||||
|
.UL ic.h
|
||||||
|
contains type definitions, macros and
|
||||||
|
variable declarations that may be used by
|
||||||
|
ic.c and by every package.
|
||||||
|
.UL ic.c
|
||||||
|
contains the definitions of these variables,
|
||||||
|
the procedure
|
||||||
|
.UL main
|
||||||
|
and some high level I/O routines used by main.
|
||||||
|
.sp
|
||||||
|
Every package xxx consists of two files.
|
||||||
|
ic_xxx.h contains type definitions,
|
||||||
|
macros, variable declarations and
|
||||||
|
procedure declarations that may be used by
|
||||||
|
every .c file that includes this .h file.
|
||||||
|
The file ic_xxx.c provides the
|
||||||
|
definitions of these variables and
|
||||||
|
the implementation of the declared procedures.
|
||||||
|
IC uses the following packages:
|
||||||
|
.IP lookup: 18
|
||||||
|
procedures that loop up procedure, data label
|
||||||
|
and instruction label names; procedures to dump
|
||||||
|
the procedure and data label names.
|
||||||
|
.IP lib:
|
||||||
|
one procedure that gets the next useful input module;
|
||||||
|
while scanning archives, it skips unnecessary modules.
|
||||||
|
.IP aux:
|
||||||
|
several auxiliary routines.
|
||||||
|
.IP io:
|
||||||
|
low-level I/O routines that unravel the Compact
|
||||||
|
Assembly Language.
|
||||||
|
.IP put:
|
||||||
|
routines that output the intermediate code
|
||||||
|
.LP
|
||||||
6
doc/ego/il/.distr
Normal file
6
doc/ego/il/.distr
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
il1
|
||||||
|
il2
|
||||||
|
il3
|
||||||
|
il4
|
||||||
|
il5
|
||||||
|
il6
|
||||||
112
doc/ego/il/il1
Normal file
112
doc/ego/il/il1
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
Inline substitution
|
||||||
|
.NH 2
|
||||||
|
Introduction
|
||||||
|
.PP
|
||||||
|
The Inline Substitution technique (IL)
|
||||||
|
tries to decrease the overhead associated
|
||||||
|
with procedure calls (invocations).
|
||||||
|
During a procedure call, several actions
|
||||||
|
must be undertaken to set up the right
|
||||||
|
environment for the called procedure.
|
||||||
|
.[
|
||||||
|
johnson calling sequence
|
||||||
|
.]
|
||||||
|
On return from the procedure, most of these
|
||||||
|
effects must be undone.
|
||||||
|
This entire process introduces significant
|
||||||
|
costs in execution time as well as
|
||||||
|
in object code size.
|
||||||
|
.PP
|
||||||
|
The inline substitution technique replaces
|
||||||
|
some of the calls by the modified body of
|
||||||
|
the called procedure, hence eliminating
|
||||||
|
the overhead.
|
||||||
|
Furthermore, as the calling and called procedure
|
||||||
|
are now integrated, they can be optimized
|
||||||
|
together, using other techniques of the optimizer.
|
||||||
|
This often leads to extra opportunities for
|
||||||
|
optimization
|
||||||
|
.[
|
||||||
|
ball predicting effects
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
carter code generation cacm
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
scheifler inline cacm
|
||||||
|
.]
|
||||||
|
.PP
|
||||||
|
An inline substitution of a call to a procedure P increases
|
||||||
|
the size of the program, unless P is very small or P is
|
||||||
|
called only once.
|
||||||
|
In the latter case, P can be eliminated.
|
||||||
|
In practice, procedures that are called only once occur
|
||||||
|
quite frequently, due to the
|
||||||
|
introduction of structured programming.
|
||||||
|
(Carter
|
||||||
|
.[
|
||||||
|
carter umi ann arbor
|
||||||
|
.]
|
||||||
|
states that almost 50% of the Pascal procedures
|
||||||
|
he analyzed were called just once).
|
||||||
|
.PP
|
||||||
|
Scheifler
|
||||||
|
.[
|
||||||
|
scheifler inline cacm
|
||||||
|
.]
|
||||||
|
has a more general view of inline substitution.
|
||||||
|
In his model, the program under consideration is
|
||||||
|
allowed to grow by a certain amount,
|
||||||
|
i.e. code size is sacrificed to speed up the program.
|
||||||
|
The above two cases are just special cases of
|
||||||
|
his model, obtained by setting the size-change to
|
||||||
|
(approximately) zero.
|
||||||
|
He formulates the substitution problem as follows:
|
||||||
|
.IP
|
||||||
|
"Given a program, a subset of all invocations,
|
||||||
|
a maximum program size, and a maximum procedure size,
|
||||||
|
find a sequence of substitutions that minimizes
|
||||||
|
the expected execution time."
|
||||||
|
.LP
|
||||||
|
Scheifler shows that this problem is NP-complete
|
||||||
|
.[~[
|
||||||
|
aho hopcroft ullman analysis algorithms
|
||||||
|
.], chapter 10]
|
||||||
|
by reduction to the Knapsack Problem.
|
||||||
|
Heuristics will have to be used to find a near-optimal
|
||||||
|
solution.
|
||||||
|
.PP
|
||||||
|
In the following chapters we will extend
|
||||||
|
Scheifler's view and adapt it to the EM Global Optimizer.
|
||||||
|
We will first describe the transformations that have
|
||||||
|
to be applied to the EM text when a call is substituted
|
||||||
|
in line.
|
||||||
|
Next we will examine in which cases inline substitution
|
||||||
|
is not possible or desirable.
|
||||||
|
Heuristics will be developed for
|
||||||
|
chosing a good sequence of substitutions.
|
||||||
|
These heuristics make no demand on the user
|
||||||
|
(such as making profiles
|
||||||
|
.[
|
||||||
|
scheifler inline cacm
|
||||||
|
.]
|
||||||
|
or giving pragmats
|
||||||
|
.[~[
|
||||||
|
ichbiah ada military standard
|
||||||
|
.], section 6.3.2]),
|
||||||
|
although the model could easily be extended
|
||||||
|
to use such information.
|
||||||
|
Finally, we will discuss the implementation
|
||||||
|
of the IL phase of the optimizer.
|
||||||
|
.PP
|
||||||
|
We will often use the term inline expansion
|
||||||
|
as a synonym of inline substitution.
|
||||||
|
.sp 0
|
||||||
|
The inverse technique of procedure abstraction
|
||||||
|
(automatic subroutine generation)
|
||||||
|
.[
|
||||||
|
shaffer subroutine generation
|
||||||
|
.]
|
||||||
|
will not be discussed in this report.
|
||||||
93
doc/ego/il/il2
Normal file
93
doc/ego/il/il2
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
.NH 2
|
||||||
|
Parameters and local variables.
|
||||||
|
.PP
|
||||||
|
In the EM calling sequence, the calling procedure
|
||||||
|
pushes its parameters on the stack
|
||||||
|
before doing the CAL.
|
||||||
|
The called routine first saves some
|
||||||
|
status information on the stack and then
|
||||||
|
allocates space for its own locals
|
||||||
|
(also on the stack).
|
||||||
|
Usually, one special purpose register,
|
||||||
|
the Local Base (LB) register,
|
||||||
|
is used to access both the locals and the
|
||||||
|
parameters.
|
||||||
|
If memory is highly segmented,
|
||||||
|
the stack frames of the caller and the callee
|
||||||
|
may be allocated in different fragments;
|
||||||
|
an extra Argument Base (AB) register is used
|
||||||
|
in this case to access the actual parameters.
|
||||||
|
See 4.2 of
|
||||||
|
.[
|
||||||
|
keizer architecture
|
||||||
|
.]
|
||||||
|
for further details.
|
||||||
|
.PP
|
||||||
|
If a procedure call is expanded in line,
|
||||||
|
there are two problems:
|
||||||
|
.IP 1. 3
|
||||||
|
No stack frame will be allocated for the called procedure;
|
||||||
|
we must find another place to put its locals.
|
||||||
|
.IP 2.
|
||||||
|
The LB register cannot be used to access the actual
|
||||||
|
parameters;
|
||||||
|
as the CAL instruction is deleted, the LB will
|
||||||
|
still point to the local base of the \fIcalling\fR procedure.
|
||||||
|
.LP
|
||||||
|
The local variables of the called procedure will
|
||||||
|
be put in the stack frame of the calling procedure,
|
||||||
|
just after its own locals.
|
||||||
|
The size of the stack frame of the
|
||||||
|
calling procedure will be increased
|
||||||
|
during its entire lifetime.
|
||||||
|
Therefore our model will allow a
|
||||||
|
limit to be set on the number of bytes
|
||||||
|
for locals that the called procedure may have
|
||||||
|
(see next section).
|
||||||
|
.PP
|
||||||
|
There are several alternatives to access the parameters.
|
||||||
|
An actual parameter may be any auxiliary expression,
|
||||||
|
which we will refer to as
|
||||||
|
the \fIactual parameter expression\fR.
|
||||||
|
The value of this expression is stored
|
||||||
|
in a location on the stack (see above),
|
||||||
|
the \fIparameter location\fR.
|
||||||
|
.sp 0
|
||||||
|
The alternatives for accessing parameters are:
|
||||||
|
.IP -
|
||||||
|
save the value of the stackpointer at the point of the CAL
|
||||||
|
in a temporary variable X;
|
||||||
|
this variable can be used to simulate the AB register, i.e.
|
||||||
|
parameter locations are accessed via an offset to
|
||||||
|
the value of X.
|
||||||
|
.IP -
|
||||||
|
create a new temporary local variable T for
|
||||||
|
the parameter (in the stack frame of the caller);
|
||||||
|
every access to the parameter location must be changed
|
||||||
|
into an access to T.
|
||||||
|
.IP -
|
||||||
|
do not evaluate the actual parameter expression before the call;
|
||||||
|
instead, substitute this expression for every use of the
|
||||||
|
parameter location.
|
||||||
|
.LP
|
||||||
|
The first method may be expensive if X is not
|
||||||
|
put in a register.
|
||||||
|
We will not use this method.
|
||||||
|
The time required to evaluate and access the
|
||||||
|
parameters when the second method is used
|
||||||
|
will not differ much from the normal
|
||||||
|
calling sequence (i.e. not in line call).
|
||||||
|
It is not expensive, but there are no
|
||||||
|
extra savings either.
|
||||||
|
The third method is essentially the 'by name'
|
||||||
|
parameter mechanism of Algol60.
|
||||||
|
If the actual parameter is just a numeric constant,
|
||||||
|
it is advantageous to use it.
|
||||||
|
Yet, there are several circumstances
|
||||||
|
under which it cannot or should not be used.
|
||||||
|
We will deal with this in the next section.
|
||||||
|
.sp 0
|
||||||
|
In general we will use the third method,
|
||||||
|
if it is possible and desirable.
|
||||||
|
Such parameters will be called \fIin line parameters\fR.
|
||||||
|
In all other cases we will use the second method.
|
||||||
164
doc/ego/il/il3
Normal file
164
doc/ego/il/il3
Normal file
@ -0,0 +1,164 @@
|
|||||||
|
.NH 2
|
||||||
|
Feasibility and desirability analysis
|
||||||
|
.PP
|
||||||
|
Feasibility and desirability analysis
|
||||||
|
of in line substitution differ
|
||||||
|
somewhat from most other techniques.
|
||||||
|
Usually, much effort is needed to find
|
||||||
|
a feasible opportunity for optimization
|
||||||
|
(e.g. a redundant subexpression).
|
||||||
|
Desirability analysis then checks
|
||||||
|
if it is really advantageous to do
|
||||||
|
the optimization.
|
||||||
|
For IL, opportunities are easy to find.
|
||||||
|
To see if an in line expansion is
|
||||||
|
desirable will not be hard either.
|
||||||
|
Yet, the main problem is to find the most
|
||||||
|
desirable ones.
|
||||||
|
We will deal with this problem later and
|
||||||
|
we will first attend feasibility and
|
||||||
|
desirability analysis.
|
||||||
|
.PP
|
||||||
|
There are several reasons why a procedure invocation
|
||||||
|
cannot or should not be expanded in line.
|
||||||
|
.sp
|
||||||
|
A call to a procedure P cannot be expanded in line
|
||||||
|
in any of the following cases:
|
||||||
|
.IP 1. 3
|
||||||
|
The body of P is not available as EM text.
|
||||||
|
Clearly, there is no way to do the substitution.
|
||||||
|
.IP 2.
|
||||||
|
P, or any procedure called by P (transitively),
|
||||||
|
follows the chain of statically enclosing
|
||||||
|
procedures (via a LXL or LXA instruction)
|
||||||
|
or follows the chain of dynamically enclosing
|
||||||
|
procedures (via a DCH).
|
||||||
|
If the call were expanded in line,
|
||||||
|
one level would be removed from the chains,
|
||||||
|
leading to total chaos.
|
||||||
|
This chaos could be solved by patching up
|
||||||
|
every LXL, LXA or DCH in all procedures
|
||||||
|
that could be part of the chains,
|
||||||
|
but this is hard to implement.
|
||||||
|
.IP 3.
|
||||||
|
P, or any procedure called by P (transitively),
|
||||||
|
calls a procedure whose body is not
|
||||||
|
available as EM text.
|
||||||
|
The unknown procedure may use an LXL, LXA or DCH.
|
||||||
|
However, in several languages a separately
|
||||||
|
compiled procedure has no access to the
|
||||||
|
static or dynamic chain.
|
||||||
|
In this case
|
||||||
|
this point does not apply.
|
||||||
|
.IP 4.
|
||||||
|
P, or any procedure called by P (transitively),
|
||||||
|
uses the LPB instruction, which converts a
|
||||||
|
local base to an argument base;
|
||||||
|
as the locals and parameters are stored
|
||||||
|
in a non-standard way (differing from the
|
||||||
|
normal EM calling sequence) this instruction
|
||||||
|
would yield incorrect results.
|
||||||
|
.IP 5.
|
||||||
|
The total number of bytes of the parameters
|
||||||
|
of P is not known.
|
||||||
|
P may be a procedure with a variable number
|
||||||
|
of parameters or may have an array of dynamic size
|
||||||
|
as value parameter.
|
||||||
|
.LP
|
||||||
|
It is undesirable to expand a call to a procedure P in line
|
||||||
|
in any of the following cases:
|
||||||
|
.IP 1. 3
|
||||||
|
P is large, i.e. the number of EM instructions
|
||||||
|
of P exceeds some threshold.
|
||||||
|
The expanded code would be large too.
|
||||||
|
Furthermore, several programs in ACK,
|
||||||
|
including the global optimizer itself,
|
||||||
|
may run out of memory if they they have to run
|
||||||
|
in a small address space and are provided
|
||||||
|
very large procedures.
|
||||||
|
The threshold may be set to infinite,
|
||||||
|
in which case this point does not apply.
|
||||||
|
.IP 2.
|
||||||
|
P has many local variables.
|
||||||
|
All these variables would have to be allocated
|
||||||
|
in the stack frame of the calling procedure.
|
||||||
|
.PP
|
||||||
|
If a call may be expanded in line, we have to
|
||||||
|
decide how to access its parameters.
|
||||||
|
In the previous section we stated that we would
|
||||||
|
use in line parameters whenever possible and desirable.
|
||||||
|
There are several reasons why a parameter
|
||||||
|
cannot or should not be expanded in line.
|
||||||
|
.sp
|
||||||
|
No parameter of a procedure P can be expanded in line,
|
||||||
|
in any of the following cases:
|
||||||
|
.IP 1. 3
|
||||||
|
P, or any procedure called by P (transitively),
|
||||||
|
does a store-indirect or a use-indirect (i.e. through
|
||||||
|
a pointer).
|
||||||
|
However, if the front-end has generated messages
|
||||||
|
telling that certain parameters can not be accessed
|
||||||
|
indirectly, those parameters may be expanded in line.
|
||||||
|
.IP 2.
|
||||||
|
P, or any procedure called by P (transitively),
|
||||||
|
calls a procedure whose body is not available as EM text.
|
||||||
|
The unknown procedure may do a store-indirect
|
||||||
|
or a use-indirect.
|
||||||
|
However, the same remark about front-end messages
|
||||||
|
as for 1. holds here.
|
||||||
|
.IP 3.
|
||||||
|
The address of a parameter location is taken (via a LAL).
|
||||||
|
In the normal calling sequence, all parameters
|
||||||
|
are stored sequentially. If the address of one
|
||||||
|
parameter location is taken, the address of any
|
||||||
|
other parameter location can be computed from it.
|
||||||
|
Hence we must put every parameter in a temporary location;
|
||||||
|
furthermore, all these locations must be in
|
||||||
|
the same order as for the normal calling sequence.
|
||||||
|
.IP 4.
|
||||||
|
P has overlapping parameters; for example, it uses
|
||||||
|
the parameter at offset 10 both as a 2 byte and as a 4 byte
|
||||||
|
parameter.
|
||||||
|
Such code may be produced by the front ends if
|
||||||
|
the formal parameter is of some record type
|
||||||
|
with variants.
|
||||||
|
.PP
|
||||||
|
Sometimes a specific parameter must not be expanded in line.
|
||||||
|
.sp 0
|
||||||
|
An actual parameter expression cannot be expanded in line
|
||||||
|
in any of the following cases:
|
||||||
|
.IP 1. 3
|
||||||
|
P stores into the parameter location.
|
||||||
|
Even if the actual parameter expression is a simple
|
||||||
|
variable, it is incorrect to change the 'store into
|
||||||
|
formal' into a 'store into actual', because of
|
||||||
|
the parameter mechanism used.
|
||||||
|
In Pascal, the following expansion is incorrect:
|
||||||
|
.DS
|
||||||
|
procedure p (x:integer);
|
||||||
|
begin
|
||||||
|
x := 20;
|
||||||
|
end;
|
||||||
|
\&...
|
||||||
|
a := 10; \kxa := 10;
|
||||||
|
p(a); ---> \h'|\nxu'a := 20;
|
||||||
|
write(a); \h'|\nxu'write(a);
|
||||||
|
.DE
|
||||||
|
.IP 2.
|
||||||
|
P changes any of the operands of the
|
||||||
|
actual parameter expression.
|
||||||
|
If the expression is expanded and evaluated
|
||||||
|
after the operand has been changed,
|
||||||
|
the wrong value will be used.
|
||||||
|
.IP 3.
|
||||||
|
The actual parameter expression has side effects.
|
||||||
|
It must be evaluated only once,
|
||||||
|
at the place of the call.
|
||||||
|
.LP
|
||||||
|
It is undesirable to expand an actual parameter in line
|
||||||
|
in the following case:
|
||||||
|
.IP 1. 3
|
||||||
|
The parameter is used more than once
|
||||||
|
(dynamically) and the actual parameter expression
|
||||||
|
is not just a simple variable or constant.
|
||||||
|
.LP
|
||||||
135
doc/ego/il/il4
Normal file
135
doc/ego/il/il4
Normal file
@ -0,0 +1,135 @@
|
|||||||
|
.NH 2
|
||||||
|
Heuristic rules
|
||||||
|
.PP
|
||||||
|
Using the information described
|
||||||
|
in the previous section,
|
||||||
|
we can find all calls that can
|
||||||
|
be expanded in line, and for which
|
||||||
|
this expansion is desirable.
|
||||||
|
In general, we cannot expand all these calls,
|
||||||
|
so we have to choose the 'best' ones.
|
||||||
|
With every CAL instruction
|
||||||
|
that may be expanded, we associate
|
||||||
|
a \fIpay off\fR,
|
||||||
|
which expresses how desirable it is
|
||||||
|
to expand this specific CAL.
|
||||||
|
.sp
|
||||||
|
Let Tc denote the portion of EM text involved
|
||||||
|
in a specific call, i.e. the pushing of the actual
|
||||||
|
parameter expressions, the CAL itself,
|
||||||
|
the popping of the parameters and the
|
||||||
|
pushing of the result (if any, via an LFR).
|
||||||
|
Let Te denote the EM text that would be obtained
|
||||||
|
by expanding the call in line.
|
||||||
|
Let Pc be the original program and Pe the program
|
||||||
|
with Te substituted for Tc.
|
||||||
|
The pay off of the CAL depends on two factors:
|
||||||
|
.IP -
|
||||||
|
T = execution_time(Pe) - execution_time(Pc)
|
||||||
|
.IP -
|
||||||
|
S = code_size(Pe) - code_size(Pc)
|
||||||
|
.LP
|
||||||
|
The change in execution time (T) depends on:
|
||||||
|
.IP -
|
||||||
|
T1 = execution_time(Te) - execution_time(Tc)
|
||||||
|
.IP -
|
||||||
|
N = number of times Te or Tc get executed.
|
||||||
|
.LP
|
||||||
|
We assume that T1 will be the same every
|
||||||
|
time the code gets executed.
|
||||||
|
This is a reasonable assumption.
|
||||||
|
(Note that we are talking about one CAL,
|
||||||
|
not about different calls to the same procedure).
|
||||||
|
Hence
|
||||||
|
.DS
|
||||||
|
T = N * T1
|
||||||
|
.DE
|
||||||
|
T1 can be estimated by a careful analysis
|
||||||
|
of the transformations that are performed.
|
||||||
|
Below, we list everything that will be
|
||||||
|
different when a call is expanded in line:
|
||||||
|
.IP -
|
||||||
|
The CAL instruction is not executed.
|
||||||
|
This saves a subroutine jump.
|
||||||
|
.IP -
|
||||||
|
The instructions in the procedure prolog
|
||||||
|
are not executed.
|
||||||
|
These instructions, generated from the PRO pseudo,
|
||||||
|
save some machine registers
|
||||||
|
(including the old LB), set the new LB and allocate space
|
||||||
|
for the locals of the called routine.
|
||||||
|
The savings may be less if there are no
|
||||||
|
locals to allocate.
|
||||||
|
.IP -
|
||||||
|
In line parameters are not evaluated before the call
|
||||||
|
and are not pushed on the stack.
|
||||||
|
.IP -
|
||||||
|
All remaining parameters are stored in local variables,
|
||||||
|
instead of being pushed on the stack.
|
||||||
|
.IP -
|
||||||
|
If the number of parameters is nonzero,
|
||||||
|
the ASP instruction after the CAL is not executed.
|
||||||
|
.IP -
|
||||||
|
Every reference to an in line parameter is
|
||||||
|
substituted by the parameter expression.
|
||||||
|
.IP -
|
||||||
|
RET (return) instructions are replaced by
|
||||||
|
BRA (branch) instructions.
|
||||||
|
If the called procedure 'falls through'
|
||||||
|
(i.e. it has only one RET, at the end of its code),
|
||||||
|
even the BRA is not needed.
|
||||||
|
.IP -
|
||||||
|
The LFR (fetch function result) is not executed
|
||||||
|
.PP
|
||||||
|
Besides these changes, which are caused directly by IL,
|
||||||
|
other changes may occur as IL influences other optimization
|
||||||
|
techniques, such as Register Allocation and Constant Propagation.
|
||||||
|
Our heuristic rules do not take into account the quite
|
||||||
|
inpredictable effects on Register Allocation.
|
||||||
|
It does, however, favour calls that have numeric \fIconstants\fR
|
||||||
|
as parameter; especially the constant "0" as an inline
|
||||||
|
parameter gets high scores,
|
||||||
|
as further optimizations may often be possible.
|
||||||
|
.PP
|
||||||
|
It cannot be determined statically how often a CAL instruction gets
|
||||||
|
executed.
|
||||||
|
We will use \fIloop nesting\fR information here.
|
||||||
|
The nesting level of the loop in which
|
||||||
|
the CAL appears (if any) will be used as an
|
||||||
|
indication for the number of times it gets executed.
|
||||||
|
.PP
|
||||||
|
Based on all these facts,
|
||||||
|
the pay off of a call will be computed.
|
||||||
|
The following model was developed empirically.
|
||||||
|
Assume procedure P calls procedure Q.
|
||||||
|
The call takes place in basic block B.
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l l.
|
||||||
|
ZP \&= # zero parameters
|
||||||
|
CP \&= # constant parameters - ZP
|
||||||
|
LN \&= Loop Nesting level (0 if outside any loop)
|
||||||
|
F \&= \fIif\fR # formal parameters of Q > 0 \fIthen\fR 1 \fIelse\fR 0
|
||||||
|
FT \&= \fIif\fR Q falls through \fIthen\fR 1 \fIelse\fR 0
|
||||||
|
S \&= size(Q) - 1 - # inline_parameters - F
|
||||||
|
L \&= \fIif\fR # local variables of P > 0 \fIthen\fR 0 \fIelse\fR -1
|
||||||
|
A \&= CP + 2 * ZP
|
||||||
|
N \&= \fIif\fR LN=0 and P is never called from a loop \fIthen\fR 0 \fIelse\fR (LN+1)**2
|
||||||
|
FM \&= \fIif\fR B is a firm block \fIthen\fR 2 \fIelse\fR 1
|
||||||
|
|
||||||
|
pay_off \&= (100/S + FT + F + L + A) * N * FM
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
S stands for the size increase of the program,
|
||||||
|
which is slightly less than the size of Q.
|
||||||
|
The size of a procedure is taken to be its number
|
||||||
|
of (non-pseudo) EM instructions.
|
||||||
|
The terms "loop nesting level" and "firm" were defined
|
||||||
|
in the chapter on the Intermediate Code (section "loop tables").
|
||||||
|
If a call is not inside a loop and the calling procedure
|
||||||
|
is itself never called from a loop (transitively),
|
||||||
|
then the call will probably be executed at most once.
|
||||||
|
Such a call is never expanded in line (its pay off is zero).
|
||||||
|
If the calling procedure doesn't have local variables, a penalty (L)
|
||||||
|
is introduced, as it will most likely get local variables if the
|
||||||
|
call gets expanded.
|
||||||
446
doc/ego/il/il5
Normal file
446
doc/ego/il/il5
Normal file
@ -0,0 +1,446 @@
|
|||||||
|
.NH 2
|
||||||
|
Implementation
|
||||||
|
.PP
|
||||||
|
A major factor in the implementation
|
||||||
|
of Inline Substitution is the requirement
|
||||||
|
not to use an excessive amount of memory.
|
||||||
|
IL essentially analyzes the entire program;
|
||||||
|
it makes decisions based on which procedure calls
|
||||||
|
appear in the whole program.
|
||||||
|
Yet, because of the memory restriction, it is
|
||||||
|
not feasible to read the entire program
|
||||||
|
in main memory.
|
||||||
|
To solve this problem, the IL phase has been
|
||||||
|
split up into three subphases that are executed sequentially:
|
||||||
|
.IP 1.
|
||||||
|
analyze every procedure; see how it accesses its parameters;
|
||||||
|
simultaneously collect all calls
|
||||||
|
appearing in the whole program an put them
|
||||||
|
in a \fIcall-list\fR.
|
||||||
|
.IP 2.
|
||||||
|
use the call-list and decide which calls will be substituted
|
||||||
|
in line.
|
||||||
|
.IP 3.
|
||||||
|
take the decisions of subphase 2 and modify the
|
||||||
|
program accordingly.
|
||||||
|
.LP
|
||||||
|
Subphases 1 and 3 scan the input program; only
|
||||||
|
subphase 3 modifies it.
|
||||||
|
It is essential that the decisions can be made
|
||||||
|
in subphase 2
|
||||||
|
without using the input program,
|
||||||
|
provided that subphase 1 puts enough information
|
||||||
|
in the call-list.
|
||||||
|
Subphase 2 keeps the entire call-list in main memory
|
||||||
|
and repeatedly scans it, to
|
||||||
|
find the next best candidate for expansion.
|
||||||
|
.PP
|
||||||
|
We will specify the
|
||||||
|
data structures used by IL before
|
||||||
|
describing the subphases.
|
||||||
|
.NH 3
|
||||||
|
Data structures
|
||||||
|
.NH 4
|
||||||
|
The procedure table
|
||||||
|
.PP
|
||||||
|
In subphase 1 information is gathered about every procedure
|
||||||
|
and added to the procedure table.
|
||||||
|
This information is used by the heuristic rules.
|
||||||
|
A proctable entry for procedure p has
|
||||||
|
the following extra information:
|
||||||
|
.IP -
|
||||||
|
is it allowed to substitute an invocation of p in line?
|
||||||
|
.IP -
|
||||||
|
is it allowed to put any parameter of such a call in line?
|
||||||
|
.IP -
|
||||||
|
the size of p (number of EM instructions)
|
||||||
|
.IP -
|
||||||
|
does p 'fall through'?
|
||||||
|
.IP -
|
||||||
|
a description of the formal parameters that p accesses; this information
|
||||||
|
is obtained by looking at the code of p. For every parameter f,
|
||||||
|
we record:
|
||||||
|
.RS
|
||||||
|
.IP -
|
||||||
|
the offset of f
|
||||||
|
.IP -
|
||||||
|
the type of f (word, double word, pointer)
|
||||||
|
.IP -
|
||||||
|
may the corresponding actual parameter be put in line?
|
||||||
|
.IP -
|
||||||
|
is f ever accessed indirectly?
|
||||||
|
.IP -
|
||||||
|
if f used: never, once or more than once?
|
||||||
|
.RE
|
||||||
|
.IP -
|
||||||
|
the number of times p is called (see below)
|
||||||
|
.IP -
|
||||||
|
the file address of its call-count information (see below).
|
||||||
|
.LP
|
||||||
|
.NH 4
|
||||||
|
Call-count information
|
||||||
|
.PP
|
||||||
|
As a result of Inline Substitution, some procedures may
|
||||||
|
become useless, because all their invocations have been
|
||||||
|
substituted in line.
|
||||||
|
One of the tasks of IL is to keep track which
|
||||||
|
procedures are no longer called.
|
||||||
|
Note that IL is especially keen on procedures that are
|
||||||
|
called only once
|
||||||
|
(possibly as a result of expanding all other calls to it).
|
||||||
|
So we want to know how many times a procedure
|
||||||
|
is called \fIduring\fR Inline Substitution.
|
||||||
|
It is not good enough to compute this
|
||||||
|
information afterwards.
|
||||||
|
The task is rather complex, because
|
||||||
|
the number of times a procedure is called
|
||||||
|
varies during the entire process:
|
||||||
|
.IP 1.
|
||||||
|
If a call to p is substituted in line,
|
||||||
|
the number of calls to p gets decremented by 1.
|
||||||
|
.IP 2.
|
||||||
|
If a call to p is substituted in line,
|
||||||
|
and p contains n calls to q, then the number of calls to q
|
||||||
|
gets incremented by n.
|
||||||
|
.IP 3.
|
||||||
|
If a procedure p is removed (because it is no
|
||||||
|
longer called) and p contains n calls to q,
|
||||||
|
then the number of calls to q gets decremented by n.
|
||||||
|
.LP
|
||||||
|
(Note that p may be the same as q, if p is recursive).
|
||||||
|
.sp 0
|
||||||
|
So we actually want to have the following information:
|
||||||
|
.DS
|
||||||
|
NRCALL(p,q) = number of call to q appearing in p,
|
||||||
|
|
||||||
|
for all procedures p and q that may be put in line.
|
||||||
|
.DE
|
||||||
|
This information, called \fIcall-count information\fR is
|
||||||
|
computed by the first subphase.
|
||||||
|
It is stored in a file.
|
||||||
|
It is represented as a number of lists, rather than as
|
||||||
|
a (very sparse) matrix.
|
||||||
|
Every procedure has a list of (proc,count) pairs,
|
||||||
|
telling which procedures it calls, and how many times.
|
||||||
|
The file address of its call-count list is stored
|
||||||
|
in its proctable entry.
|
||||||
|
Whenever this information is needed, it is fetched from
|
||||||
|
the file, using direct access.
|
||||||
|
The proctable entry also contains the number of times
|
||||||
|
a procedure is called, at any moment.
|
||||||
|
.NH 4
|
||||||
|
The call-list
|
||||||
|
.PP
|
||||||
|
The call-list is the major data structure use by IL.
|
||||||
|
Every item of the list describes one procedure call.
|
||||||
|
It contains the following attributes:
|
||||||
|
.IP -
|
||||||
|
the calling procedure (caller)
|
||||||
|
.IP -
|
||||||
|
the called procedure (callee)
|
||||||
|
.IP -
|
||||||
|
identification of the CAL instruction (sequence number)
|
||||||
|
.IP -
|
||||||
|
the loop nesting level; our heuristic rules appreciate
|
||||||
|
calls inside a loop (or even inside a loop nested inside
|
||||||
|
another loop, etc.) more than other calls
|
||||||
|
.IP -
|
||||||
|
the actual parameter expressions involved in the call;
|
||||||
|
for every actual, we record:
|
||||||
|
.RS
|
||||||
|
.IP -
|
||||||
|
the EM code of the expression
|
||||||
|
.IP -
|
||||||
|
the number of bytes of its result (size)
|
||||||
|
.IP -
|
||||||
|
an indication if the actual may be put in line
|
||||||
|
.RE
|
||||||
|
.LP
|
||||||
|
The structure of the call-list is rather complex.
|
||||||
|
Whenever a call is expanded in line, new calls
|
||||||
|
will suddenly appear in the program,
|
||||||
|
that were not contained in the original body
|
||||||
|
of the calling subroutine.
|
||||||
|
These calls are inherited from the called procedure.
|
||||||
|
We will refer to these invocations as \fInested calls\fR
|
||||||
|
(see Fig. 5.1).
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
lw(2.5i) l.
|
||||||
|
procedure p is
|
||||||
|
begin .
|
||||||
|
a(); .
|
||||||
|
b(); .
|
||||||
|
end;
|
||||||
|
.TE
|
||||||
|
|
||||||
|
.TS
|
||||||
|
lw(2.5i) l.
|
||||||
|
procedure r is procedure r is
|
||||||
|
begin begin
|
||||||
|
x(); x();
|
||||||
|
p(); -- in line a(); -- nested call
|
||||||
|
y(); b(); -- nested call
|
||||||
|
end; y();
|
||||||
|
end;
|
||||||
|
.TE
|
||||||
|
|
||||||
|
Fig. 5.1 Example of nested procedure calls
|
||||||
|
.DE
|
||||||
|
Nested calls may subsequently be put in line too
|
||||||
|
(probably resulting in a yet deeper nesting level, etc.).
|
||||||
|
So the call-list does not always reflect the source program,
|
||||||
|
but changes dynamically, as decisions are made.
|
||||||
|
If a call to p is expanded, all calls appearing in p
|
||||||
|
will be added to the call-list.
|
||||||
|
.sp 0
|
||||||
|
A convenient and elegant way to represent
|
||||||
|
the call-list is to use a LISP-like list.
|
||||||
|
.[
|
||||||
|
poel lisp trac
|
||||||
|
.]
|
||||||
|
Calls that appear at the same level
|
||||||
|
are linked in the CDR direction. If a call C
|
||||||
|
to a procedure p is expanded,
|
||||||
|
all calls appearing in p are put in a sub-list
|
||||||
|
of C, i.e. in its CAR.
|
||||||
|
In the example above, before the decision
|
||||||
|
to expand the call to p is made, the
|
||||||
|
call-list of procedure r looks like:
|
||||||
|
.DS
|
||||||
|
(call-to-x, call-to-p, call-to-y)
|
||||||
|
.DE
|
||||||
|
After the decision, it looks like:
|
||||||
|
.DS
|
||||||
|
(call-to-x, (call-to-p*, call-to-a, call-to-b), call-to-y)
|
||||||
|
.DE
|
||||||
|
The call to p is marked, because it has been
|
||||||
|
substituted.
|
||||||
|
Whenever IL wants to traverse the call-list of some procedure,
|
||||||
|
it uses the well-known LISP technique of
|
||||||
|
recursion in the CAR direction and
|
||||||
|
iteration in the CDR direction
|
||||||
|
(see page 1.19-2 of
|
||||||
|
.[
|
||||||
|
poel lisp trac
|
||||||
|
.]
|
||||||
|
).
|
||||||
|
All list traversals look like:
|
||||||
|
.DS
|
||||||
|
traverse(list)
|
||||||
|
{
|
||||||
|
for (c = first(list); c != 0; c = CDR(c)) {
|
||||||
|
if (c is marked) {
|
||||||
|
traverse(CAR(c));
|
||||||
|
} else {
|
||||||
|
do something with c
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.DE
|
||||||
|
The entire call-list consists of a number of LISP-like lists,
|
||||||
|
one for every procedure.
|
||||||
|
The proctable entry of a procedure contains a pointer
|
||||||
|
to the beginning of the list.
|
||||||
|
.NH 3
|
||||||
|
The first subphase: procedure analysis
|
||||||
|
.PP
|
||||||
|
The tasks of the first subphase are to determine
|
||||||
|
several attributes of every procedure
|
||||||
|
and to construct the basic call-list,
|
||||||
|
i.e. without nested calls.
|
||||||
|
The size of a procedure is determined
|
||||||
|
by simply counting its EM instructions.
|
||||||
|
Pseudo instructions are skipped.
|
||||||
|
A procedure does not 'fall through' if its CFG
|
||||||
|
contains a basic block
|
||||||
|
that is not the last block of the CFG and
|
||||||
|
that ends on a RET instruction.
|
||||||
|
The formal parameters of a procedure are determined
|
||||||
|
by inspection of
|
||||||
|
its code.
|
||||||
|
.PP
|
||||||
|
The call-list in constructed by looking at all CAL instructions
|
||||||
|
appearing in the program.
|
||||||
|
The call-list should only contain calls to procedures
|
||||||
|
that may be put in line.
|
||||||
|
This fact is only known if the procedure was
|
||||||
|
analyzed earlier.
|
||||||
|
If a call to a procedure p appears in the program
|
||||||
|
before the body of p,
|
||||||
|
the call will always be put in the call-list.
|
||||||
|
If p is later found to be unsuitable,
|
||||||
|
the call will be removed from the list by the
|
||||||
|
second subphase.
|
||||||
|
.PP
|
||||||
|
An important issue is the recognition
|
||||||
|
of the actual parameter expressions of the call.
|
||||||
|
The front ends produces messages telling how many
|
||||||
|
bytes of formal parameters every procedure accesses.
|
||||||
|
(If there is no such message for a procedure, it
|
||||||
|
cannot be put in line).
|
||||||
|
The actual parameters together must account for
|
||||||
|
the same number of bytes.A recursive descent parser is used
|
||||||
|
to parse side-effect free EM expressions.
|
||||||
|
It uses a table and some
|
||||||
|
auxiliary routines to determine
|
||||||
|
how many bytes every EM instruction pops from the stack
|
||||||
|
and how many bytes it pushes onto the stack.
|
||||||
|
These numbers depend on the EM instruction, its argument,
|
||||||
|
and the wordsize and pointersize of the target machine.
|
||||||
|
Initially, the parser has to recognize the
|
||||||
|
number of bytes specified in the formals-message,
|
||||||
|
say N.
|
||||||
|
Assume the first instruction before the CAL pops S bytes
|
||||||
|
and pushes R bytes.
|
||||||
|
If R > N, too many bytes are recognized
|
||||||
|
and the parser fails.
|
||||||
|
Else, it calls itself recursively to recognize the
|
||||||
|
S bytes used as operand of the instruction.
|
||||||
|
If it succeeds in doing so, it continues with the next instruction,
|
||||||
|
i.e. the first instruction before the code recognized by
|
||||||
|
the recursive call, to recognize N-R more bytes.
|
||||||
|
The result is a number of EM instructions that collectively push N bytes.
|
||||||
|
If an instruction is come across that has side-effects
|
||||||
|
(e.g. a store or a procedure call) or of which R and S cannot
|
||||||
|
be computed statically (e.g. a LOS), it fails.
|
||||||
|
.sp 0
|
||||||
|
Note that the parser traverses the code backwards.
|
||||||
|
As EM code is essentially postfix code, the parser works top down.
|
||||||
|
.PP
|
||||||
|
If the parser fails to recognize the parameters, the call will not
|
||||||
|
be substituted in line.
|
||||||
|
If the parameters can be determined, they still have to
|
||||||
|
match the formal parameters of the called procedure.
|
||||||
|
This check is performed by the second subphase; it cannot be
|
||||||
|
done here, because it is possible that the called
|
||||||
|
procedure has not been analyzed yet.
|
||||||
|
.PP
|
||||||
|
The entire call-list is written to a file,
|
||||||
|
to be processed by the second subphase.
|
||||||
|
.NH 3
|
||||||
|
The second subphase: making decisions
|
||||||
|
.PP
|
||||||
|
The task of the second subphase is quite easy
|
||||||
|
to understand.
|
||||||
|
It reads the call-list file,
|
||||||
|
builds an incore call-list and deletes every
|
||||||
|
call that may not be expanded in line (either because the called
|
||||||
|
procedure may not be put in line, or because the actual parameters
|
||||||
|
of the call do not match the formal parameters of the called procedure).
|
||||||
|
It assigns a \fIpay-off\fR to every call,
|
||||||
|
indicating how desirable it is to expand it.
|
||||||
|
.PP
|
||||||
|
The subphase repeatedly scans the call-list and takes
|
||||||
|
the call with the highest ratio.
|
||||||
|
The chosen one gets marked,
|
||||||
|
and the call-list is extended with the nested calls,
|
||||||
|
as described above.
|
||||||
|
These nested calls are also assigned a ratio,
|
||||||
|
and will be considered too during the next scans.
|
||||||
|
.sp 0
|
||||||
|
After every decision the number of times
|
||||||
|
every procedure is called is updated, using
|
||||||
|
the call-count information.
|
||||||
|
Meanwhile, the subphase keeps track of the amount of space left
|
||||||
|
available.
|
||||||
|
If all space is used, or if there are no more calls left to
|
||||||
|
be expanded, it exits this loop.
|
||||||
|
Finally, calls to procedures that are called only
|
||||||
|
once are also chosen.
|
||||||
|
.PP
|
||||||
|
The actual parameters of a call are only needed by
|
||||||
|
this subphase to assign a ratio to a call.
|
||||||
|
To save some space, these actuals are not kept in main memory.
|
||||||
|
They are removed after the call has been read and a ratio
|
||||||
|
has been assigned to it.
|
||||||
|
So this subphase works with \fIabstracts\fR of calls.
|
||||||
|
After all work has been done,
|
||||||
|
the actual parameters of the chosen calls are retrieved
|
||||||
|
from a file,
|
||||||
|
as they are needed by the transformation subphase.
|
||||||
|
.NH 3
|
||||||
|
The third subphase: doing transformations
|
||||||
|
.PP
|
||||||
|
The third subphase makes the actual modifications to
|
||||||
|
the EM text.
|
||||||
|
It is directed by the decisions made in the previous subphase,
|
||||||
|
as expressed via the call-list.
|
||||||
|
The call-list read by this subphase contains
|
||||||
|
only calls that were selected for expansion.
|
||||||
|
The list is ordered in the same way as the EM text,
|
||||||
|
i.e. if a call C1 appears before a call C2 in the call-list,
|
||||||
|
C1 also appears before C2 in the EM text.
|
||||||
|
So the EM text is traversed linearly,
|
||||||
|
the calls that have to be substituted are determined
|
||||||
|
and the modifications are made.
|
||||||
|
If a procedure is come across that is no longer needed,
|
||||||
|
it is simply not written to the output EM file.
|
||||||
|
The substitution of a call takes place in distinct steps:
|
||||||
|
.IP "change the calling sequence" 7
|
||||||
|
.sp 0
|
||||||
|
The actual parameter expressions are changed.
|
||||||
|
Parameters that are put in line are removed.
|
||||||
|
All remaining ones must store their result in a
|
||||||
|
temporary local variable, rather than
|
||||||
|
push it on the stack.
|
||||||
|
The CAL instruction and any ASP (to pop actual parameters)
|
||||||
|
or LFR (to fetch the result of a function)
|
||||||
|
are deleted.
|
||||||
|
.IP "fetch the text of the called procedure"
|
||||||
|
.sp 0
|
||||||
|
Direct disk access is used to to read the text of the
|
||||||
|
called procedure.
|
||||||
|
The file offset is obtained from the proctable entry.
|
||||||
|
.IP "allocate bytes for locals and temporaries"
|
||||||
|
.sp 0
|
||||||
|
The local variables of the called procedure will be put in the
|
||||||
|
stack frame of the calling procedure.
|
||||||
|
The same applies to any temporary variables
|
||||||
|
that hold the result of parameters
|
||||||
|
that were not put in line.
|
||||||
|
The proctable entry of the caller is updated.
|
||||||
|
.IP "put a label after the CAL"
|
||||||
|
.sp 0
|
||||||
|
If the called procedure contains a RET (return) instruction
|
||||||
|
somewhere in the middle of its text (i.e. it does
|
||||||
|
not fall through), the RET must be changed into
|
||||||
|
a BRA (branch), to jump over the
|
||||||
|
remainder of the text.
|
||||||
|
This label is not needed if the called
|
||||||
|
procedure falls through.
|
||||||
|
.IP "copy the text of the called procedure and modify it"
|
||||||
|
.sp 0
|
||||||
|
References to local variables of the called routine
|
||||||
|
and to parameters that are not put in line
|
||||||
|
are changed to refer to the
|
||||||
|
new local of the caller.
|
||||||
|
References to in line parameters are replaced
|
||||||
|
by the actual parameter expression.
|
||||||
|
Returns (RETs) are either deleted or
|
||||||
|
replaced by a BRA.
|
||||||
|
Messages containing information about local
|
||||||
|
variables or parameters are changed.
|
||||||
|
Global data declarations and the PRO and END pseudos
|
||||||
|
are removed.
|
||||||
|
Instruction labels and references to them are
|
||||||
|
changed to make sure they do not have the
|
||||||
|
same identifying number as
|
||||||
|
labels in the calling procedure.
|
||||||
|
.IP "insert the modified text"
|
||||||
|
.sp 0
|
||||||
|
The pseudos of the called procedure are put after the pseudos
|
||||||
|
of the calling procedure.
|
||||||
|
The real text of the callee is put at
|
||||||
|
the place where the CAL was.
|
||||||
|
.IP "take care of nested substitutions"
|
||||||
|
.sp 0
|
||||||
|
The expanded procedure may contain calls that
|
||||||
|
have to be expanded too (nested calls).
|
||||||
|
If the descriptor of this call contains actual
|
||||||
|
parameter expressions,
|
||||||
|
the code of the expressions has to be changed
|
||||||
|
the same way as the code of the callee was changed.
|
||||||
|
Next, the entire process of finding CALs and doing
|
||||||
|
the substitutions is repeated recursively.
|
||||||
|
.LP
|
||||||
27
doc/ego/il/il6
Normal file
27
doc/ego/il/il6
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
.NH 2
|
||||||
|
Source files of IL
|
||||||
|
.PP
|
||||||
|
The sources of IL are in the following files
|
||||||
|
and packages (the prefixes 1_, 2_ and 3_ refer to the three subphases):
|
||||||
|
.IP il.h: 14
|
||||||
|
declarations of global variables and
|
||||||
|
data structures
|
||||||
|
.IP il.c:
|
||||||
|
the routine main; the driving routines of the three subphases
|
||||||
|
.IP 1_anal:
|
||||||
|
contains a subroutine that analyzes a procedure
|
||||||
|
.IP 1_cal:
|
||||||
|
contains a subroutine that analyzes a call
|
||||||
|
.IP 1_aux:
|
||||||
|
implements auxiliary procedures used by subphase 1
|
||||||
|
.IP 2_aux:
|
||||||
|
implements auxiliary procedures used by subphase 2
|
||||||
|
.IP 3_subst:
|
||||||
|
the driving routine for doing the substitution
|
||||||
|
.IP 3_change:
|
||||||
|
lower level routines that do certain modifications
|
||||||
|
.IP 3_aux:
|
||||||
|
implements auxiliary procedures used by subphase 3
|
||||||
|
.IP aux:
|
||||||
|
implements auxiliary procedures used by several subphases.
|
||||||
|
.LP
|
||||||
3
doc/ego/intro/.distr
Normal file
3
doc/ego/intro/.distr
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
head
|
||||||
|
intro1
|
||||||
|
tail
|
||||||
10
doc/ego/intro/head
Normal file
10
doc/ego/intro/head
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
.ND
|
||||||
|
.\".ll 80m
|
||||||
|
.\".nr LL 80m
|
||||||
|
.\".nr tl 78m
|
||||||
|
.tr ~
|
||||||
|
.ds >. .
|
||||||
|
.ds >, ,
|
||||||
|
.ds [. " [
|
||||||
|
.ds .] ]
|
||||||
|
.cs 5 22
|
||||||
79
doc/ego/intro/intro1
Normal file
79
doc/ego/intro/intro1
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
.TL
|
||||||
|
The design and implementation of
|
||||||
|
the EM Global Optimizer
|
||||||
|
.AU
|
||||||
|
H.E. Bal
|
||||||
|
.AI
|
||||||
|
Vrije Universiteit
|
||||||
|
Wiskundig Seminarium, Amsterdam
|
||||||
|
.AB
|
||||||
|
The EM Global Optimizer is part of the Amsterdam Compiler Kit,
|
||||||
|
a toolkit for making retargetable compilers.
|
||||||
|
It optimizes the intermediate code common to all compilers of
|
||||||
|
the toolkit (EM),
|
||||||
|
so it can be used for all programming languages and
|
||||||
|
all processors supported by the kit.
|
||||||
|
.PP
|
||||||
|
The optimizer is based on well-understood concepts like
|
||||||
|
control flow analysis and data flow analysis.
|
||||||
|
It performs the following optimizations:
|
||||||
|
Inline Substitution, Strength Reduction, Common Subexpression Elimination,
|
||||||
|
Stack Pollution, Cross Jumping, Branch Optimization, Copy Propagation,
|
||||||
|
Constant Propagation, Dead Code Elimination and Register Allocation.
|
||||||
|
.PP
|
||||||
|
This report describes the design of the optimizer and several
|
||||||
|
of its implementation issues.
|
||||||
|
.AE
|
||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
Introduction
|
||||||
|
.PP
|
||||||
|
.FS
|
||||||
|
This work was supported by the
|
||||||
|
Stichting Technische Wetenschappen (STW)
|
||||||
|
under grant VWI00.0001.
|
||||||
|
.FE
|
||||||
|
The EM Global Optimizer is part of a software toolkit
|
||||||
|
for making production-quality retargetable compilers.
|
||||||
|
This toolkit,
|
||||||
|
called the Amsterdam Compiler Kit
|
||||||
|
.[
|
||||||
|
tanenbaum toolkit rapport
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
tanenbaum toolkit cacm
|
||||||
|
.]
|
||||||
|
runs under the Unix*
|
||||||
|
.FS
|
||||||
|
*Unix is a Trademark of Bell Laboratories
|
||||||
|
.FE
|
||||||
|
operating system.
|
||||||
|
.sp 0
|
||||||
|
The main design philosophy of the toolkit is to use
|
||||||
|
a language- and machine-independent
|
||||||
|
intermediate code, called EM.
|
||||||
|
.[
|
||||||
|
keizer architecture
|
||||||
|
.]
|
||||||
|
The basic compilation process can be split up into
|
||||||
|
two parts.
|
||||||
|
A language-specific front end translates the source program into EM.
|
||||||
|
A machine-specific back end transforms EM to assembly code
|
||||||
|
of the target machine.
|
||||||
|
.PP
|
||||||
|
The global optimizer is an optional phase of the
|
||||||
|
compilation process, and can be used to obtain
|
||||||
|
machine code of a higher quality.
|
||||||
|
The optimizer transforms EM-code to better EM-code,
|
||||||
|
so it comes between the front end and the back end.
|
||||||
|
It can be used with any combination of languages
|
||||||
|
and machines, as far as they are supported by
|
||||||
|
the compiler kit.
|
||||||
|
.PP
|
||||||
|
This report describes the design of the
|
||||||
|
global optimizer and several of its
|
||||||
|
implementation issues.
|
||||||
|
Measurements can be found in.
|
||||||
|
.[
|
||||||
|
bal tanenbaum global
|
||||||
|
.]
|
||||||
17
doc/ego/intro/tail
Normal file
17
doc/ego/intro/tail
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
.SH
|
||||||
|
Acknowledgements
|
||||||
|
.PP
|
||||||
|
The author would like to thank Andy Tanenbaum for his guidance,
|
||||||
|
Duk Bekema for implementing the Common Subexpression Elimination phase
|
||||||
|
and writing the initial documentation of that phase,
|
||||||
|
Dick Grune for reading the manuscript of this report
|
||||||
|
and Ceriel Jacobs, Ed Keizer, Martin Kersten, Hans van Staveren
|
||||||
|
and the members of the S.T.W. user's group for their
|
||||||
|
interest and assistance.
|
||||||
|
.bp
|
||||||
|
.SH
|
||||||
|
References
|
||||||
|
.LP
|
||||||
|
.[
|
||||||
|
$LIST$
|
||||||
|
.]
|
||||||
1
doc/ego/lv/.distr
Normal file
1
doc/ego/lv/.distr
Normal file
@ -0,0 +1 @@
|
|||||||
|
lv1
|
||||||
95
doc/ego/lv/lv1
Normal file
95
doc/ego/lv/lv1
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
Live-Variable analysis
|
||||||
|
.NH 2
|
||||||
|
Introduction
|
||||||
|
.PP
|
||||||
|
The "Live-Variable analysis" optimization technique (LV)
|
||||||
|
performs some code improvements and computes information that may be
|
||||||
|
used by subsequent optimizations.
|
||||||
|
The main task of this phase is the
|
||||||
|
computation of \fIlive-variable information\fR.
|
||||||
|
.[~[
|
||||||
|
aho compiler design
|
||||||
|
.] section 14.4]
|
||||||
|
A variable A is said to be \fIdead\fR at some point p of the
|
||||||
|
program text, if on no path in the control flow graph
|
||||||
|
from p to a RET (return), A can be used before being changed;
|
||||||
|
else A is said to be \fIlive\fR.
|
||||||
|
.PP
|
||||||
|
A statement of the form
|
||||||
|
.DS
|
||||||
|
VARIABLE := EXPRESSION
|
||||||
|
.DE
|
||||||
|
is said to be dead if the left hand side variable is dead just after
|
||||||
|
the statement and the right hand side expression has no
|
||||||
|
side effects (i.e. it doesn't change any variable).
|
||||||
|
Such a statement can be eliminated entirely.
|
||||||
|
Dead code will seldom be present in the original program,
|
||||||
|
but it may be the result of earlier optimizations,
|
||||||
|
such as copy propagation.
|
||||||
|
.PP
|
||||||
|
Live-variable information is passed to other phases via
|
||||||
|
messages in the EM code.
|
||||||
|
Live/dead messages are generated at points in the EM text where
|
||||||
|
variables become dead or live.
|
||||||
|
This information is especially useful for the Register
|
||||||
|
Allocation phase.
|
||||||
|
.NH 2
|
||||||
|
Implementation
|
||||||
|
.PP
|
||||||
|
The implementation uses algorithm 14.6 of.
|
||||||
|
.[
|
||||||
|
aho compiler design
|
||||||
|
.]
|
||||||
|
First two sets DEF and USE are computed for every basic block b:
|
||||||
|
.IP DEF(b) 9
|
||||||
|
the set of all variables that are assigned a value in b before
|
||||||
|
being used
|
||||||
|
.IP USE(b) 9
|
||||||
|
the set of all variables that may be used in b before being changed.
|
||||||
|
.LP
|
||||||
|
(So variables that may, but need not, be used resp. changed via a procedure
|
||||||
|
call or through a pointer are included in USE but not in DEF).
|
||||||
|
The next step is to compute the sets IN and OUT :
|
||||||
|
.IP IN[b] 9
|
||||||
|
the set of all variables that are live at the beginning of b
|
||||||
|
.IP OUT[b] 9
|
||||||
|
the set of all variables that are live at the end of b
|
||||||
|
.LP
|
||||||
|
IN and OUT can be computed for all blocks simultaneously by solving the
|
||||||
|
data flow equations:
|
||||||
|
.DS
|
||||||
|
(1) IN[b] = OUT[b] - DEF[b] + USE[b]
|
||||||
|
[2] OUT[b] = IN[s1] + ... + IN[sn] ;
|
||||||
|
where SUCC[b] = {s1, ... , sn}
|
||||||
|
.DE
|
||||||
|
The equations are solved by a similar algorithm as for
|
||||||
|
the Use Definition equations (see previous chapter).
|
||||||
|
.PP
|
||||||
|
Finally, each basic block is visited in turn to remove its dead code
|
||||||
|
and to emit the live/dead messages.
|
||||||
|
Every basic block b is traversed from its last
|
||||||
|
instruction backwards to the beginning of b.
|
||||||
|
Initially, all variables that are dead at the end
|
||||||
|
of b are marked dead. All others are marked live.
|
||||||
|
If we come across an assignment to a variable X that
|
||||||
|
was marked live, a live-message is put after the
|
||||||
|
assignment and X is marked dead;
|
||||||
|
if X was marked dead, the assignment may be removed, provided that
|
||||||
|
the right hand side expression contains no side effects.
|
||||||
|
If we come across a use of a variable X that
|
||||||
|
was marked dead, a dead-message is put after the
|
||||||
|
use and X is marked live.
|
||||||
|
So at any point, the mark of X tells whether X is
|
||||||
|
live or dead immediately before that point.
|
||||||
|
A message is also generated at the start of a basic block
|
||||||
|
for every variable that was live at the end of the (textually)
|
||||||
|
previous block, but dead at the entry of this block, or v.v.
|
||||||
|
.PP
|
||||||
|
Only local variables are considered.
|
||||||
|
This significantly reduces the memory needed by this phase,
|
||||||
|
eases the implementation and is hardly less efficient than
|
||||||
|
considering all variables.
|
||||||
|
(Note that it is very hard to prove that an assignment to
|
||||||
|
a global variable is dead).
|
||||||
1
doc/ego/ov/.distr
Normal file
1
doc/ego/ov/.distr
Normal file
@ -0,0 +1 @@
|
|||||||
|
ov1
|
||||||
374
doc/ego/ov/ov1
Normal file
374
doc/ego/ov/ov1
Normal file
@ -0,0 +1,374 @@
|
|||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
Overview of the global optimizer
|
||||||
|
.NH 2
|
||||||
|
The ACK compilation process
|
||||||
|
.PP
|
||||||
|
The EM Global Optimizer is one of three optimizers that are
|
||||||
|
part of the Amsterdam Compiler Kit (ACK).
|
||||||
|
The phases of ACK are:
|
||||||
|
.IP 1.
|
||||||
|
A Front End translates a source program to EM
|
||||||
|
.IP 2.
|
||||||
|
The Peephole Optimizer
|
||||||
|
.[
|
||||||
|
tanenbaum staveren peephole toplass
|
||||||
|
.]
|
||||||
|
reads EM code and produces 'better' EM code.
|
||||||
|
It performs a number of optimizations (mostly peephole
|
||||||
|
optimizations)
|
||||||
|
such as constant folding, strength reduction and unreachable code
|
||||||
|
elimination.
|
||||||
|
.IP 3.
|
||||||
|
The Global Optimizer further improves the EM code.
|
||||||
|
.IP 4.
|
||||||
|
The Code Generator transforms EM to assembly code
|
||||||
|
of the target computer.
|
||||||
|
.IP 5.
|
||||||
|
The Target Optimizer improves the assembly code.
|
||||||
|
.IP 6.
|
||||||
|
An Assembler/Loader generates an executable file.
|
||||||
|
.LP
|
||||||
|
For a more extensive overview of the ACK compilation process,
|
||||||
|
we refer to.
|
||||||
|
.[
|
||||||
|
tanenbaum toolkit rapport
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
tanenbaum toolkit cacm
|
||||||
|
.]
|
||||||
|
.PP
|
||||||
|
The input of the Global Optimizer may consist of files and
|
||||||
|
libraries.
|
||||||
|
Every file or module in the library must contain EM code in
|
||||||
|
Compact Assembly Language format.
|
||||||
|
.[~[
|
||||||
|
tanenbaum machine architecture
|
||||||
|
.], section 11.2]
|
||||||
|
The output consists of one such EM file.
|
||||||
|
The input files and libraries together need not
|
||||||
|
constitute an entire program,
|
||||||
|
although as much of the program as possible should be supplied.
|
||||||
|
The more information about the program the optimizer
|
||||||
|
gets, the better its output code will be.
|
||||||
|
.PP
|
||||||
|
The Global Optimizer is language- and machine-independent,
|
||||||
|
i.e. it can be used for all languages and machines supported by ACK.
|
||||||
|
Yet, it puts some unavoidable restrictions on the EM code
|
||||||
|
produced by the Front End (see below).
|
||||||
|
It must have some knowledge of the target machine.
|
||||||
|
This knowledge is expressed in a machine description table
|
||||||
|
which is passed as argument to the optimizer.
|
||||||
|
This table does not contain very detailed information about the
|
||||||
|
target (such as its instruction set and addressing modes).
|
||||||
|
.NH 2
|
||||||
|
The EM code
|
||||||
|
.PP
|
||||||
|
The definition of EM, the intermediate code of all ACK compilers,
|
||||||
|
is given in a separate document.
|
||||||
|
.[
|
||||||
|
tanenbaum machine architecture
|
||||||
|
.]
|
||||||
|
We will only discuss some features of EM that are most relevant
|
||||||
|
to the Global Optimizer.
|
||||||
|
.PP
|
||||||
|
EM is the assembly code of a virtual \fIstack machine\fR.
|
||||||
|
All operations are performed on the top of the stack.
|
||||||
|
For example, the statement "A := B + 3" may be expressed in EM as:
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
LOL -4 -- push local variable B
|
||||||
|
LOC 3 -- push constant 3
|
||||||
|
ADI 2 -- add two 2-byte items on top of
|
||||||
|
-- the stack and push the result
|
||||||
|
STL -2 -- pop A
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
So EM is essentially a \fIpostfix\fR code.
|
||||||
|
.PP
|
||||||
|
EM has a rich instruction set, containing several arithmetic
|
||||||
|
and logical operators.
|
||||||
|
It also contains special-case instructions (such as INCrement).
|
||||||
|
.PP
|
||||||
|
EM has \fIglobal\fR (\fIexternal\fR) variables, accessible
|
||||||
|
by all procedures and \fIlocal\fR variables, accessible by a few
|
||||||
|
(nested) procedures.
|
||||||
|
The local variables of a lexically enclosing procedure may
|
||||||
|
be accessed via a \fIstatic link\fR.
|
||||||
|
EM has instructions to follow the static chain.
|
||||||
|
There are EM instruction to allow a procedure
|
||||||
|
to access its local variables directly (such as LOL and STL above).
|
||||||
|
Local variables are referenced via an offset in the stack frame
|
||||||
|
of the procedure, rather than by their names (e.g. -2 and -4 above).
|
||||||
|
The EM code does not contain the (source language) type
|
||||||
|
of the variables.
|
||||||
|
.PP
|
||||||
|
All structured statements in the source program are expressed in
|
||||||
|
low level jump instructions.
|
||||||
|
Besides conditional and unconditional branch instructions, there are
|
||||||
|
two case instructions (CSA and CSB),
|
||||||
|
to allow efficient translation of case statements.
|
||||||
|
.NH 2
|
||||||
|
Requirements on the EM input
|
||||||
|
.PP
|
||||||
|
As the optimizer should be useful for all languages,
|
||||||
|
it clearly should not put severe restrictions on the EM code
|
||||||
|
of the input.
|
||||||
|
There is, however, one immovable requirement:
|
||||||
|
it must be possible to determine the \fIflow of control\fR of the
|
||||||
|
input program.
|
||||||
|
As virtually all global optimizations are based on control flow information,
|
||||||
|
the optimizer would be totally powerless without it.
|
||||||
|
For this reason we restrict the usage of the case jump instructions (CSA/CSB)
|
||||||
|
of EM.
|
||||||
|
Such an instruction is always called with the address of a case descriptor
|
||||||
|
on top the the stack.
|
||||||
|
.[~[
|
||||||
|
tanenbaum machine architecture
|
||||||
|
.] section 7.4]
|
||||||
|
This descriptor contains the labels of all possible
|
||||||
|
destinations of the jump.
|
||||||
|
We demand that all case descriptors are allocated in a global
|
||||||
|
data fragment of type ROM, i.e. the case descriptors
|
||||||
|
may not be modifyable.
|
||||||
|
Furthermore, any case instruction should be immediately preceded by
|
||||||
|
a LAE (Load Address External) instruction, that loads the
|
||||||
|
address of the descriptor,
|
||||||
|
so the descriptor can be uniquely identified.
|
||||||
|
.PP
|
||||||
|
The optimizer will work improperly if the user deceives the control flow.
|
||||||
|
We will give two methods to do this.
|
||||||
|
.PP
|
||||||
|
In "C" the notorious library routines "setjmp" and "longjmp"
|
||||||
|
.[
|
||||||
|
unix programmer's manual McIlroy
|
||||||
|
.]
|
||||||
|
may be used to jump out of a procedure,
|
||||||
|
but can also be used for a number of other stuffy purposes,
|
||||||
|
for example, to create an extra entry point in a loop.
|
||||||
|
.DS
|
||||||
|
while (condition) {
|
||||||
|
....
|
||||||
|
setjmp(buf);
|
||||||
|
...
|
||||||
|
}
|
||||||
|
...
|
||||||
|
longjmp(buf);
|
||||||
|
.DE
|
||||||
|
The invocation to longjmp actually is a jump to the place of
|
||||||
|
the last call to setjmp with the same argument (buf).
|
||||||
|
As the calls to setjmp and longjmp are indistinguishable from
|
||||||
|
normal procedure calls, the optimizer will not see the danger.
|
||||||
|
No need to say that several loop optimizations will behave
|
||||||
|
unexpectedly when presented with such pathological input.
|
||||||
|
.PP
|
||||||
|
Another way to deceive the flow of control is
|
||||||
|
by using exception handling routines.
|
||||||
|
Ada*
|
||||||
|
.FS
|
||||||
|
* Ada is a registered trademark of the U.S. Government
|
||||||
|
(Ada Joint Program Office).
|
||||||
|
.FE
|
||||||
|
has clearly recognized the dangers of exception handling,
|
||||||
|
but other languages (such as PL/I) have not.
|
||||||
|
.[
|
||||||
|
ada rationale
|
||||||
|
.]
|
||||||
|
.PP
|
||||||
|
The optimizer will be more effective if the EM input contains
|
||||||
|
some extra information about the source program.
|
||||||
|
Especially the \fIregister message\fR is very important.
|
||||||
|
These messages indicate which local variables may never be
|
||||||
|
accessed indirectly.
|
||||||
|
Most optimizations benefit significantly by this information.
|
||||||
|
.PP
|
||||||
|
The Inline Substitution technique needs to know how many bytes
|
||||||
|
of formal parameters every procedure accesses.
|
||||||
|
Only calls to procedures for which the EM code contains this information
|
||||||
|
will be substituted in line.
|
||||||
|
.NH 2
|
||||||
|
Structure of the optimizer
|
||||||
|
.PP
|
||||||
|
The Global Optimizer is organized as a number of \fIphases\fR,
|
||||||
|
each one performing some task.
|
||||||
|
The main structure is as follows:
|
||||||
|
.IP IC 6
|
||||||
|
the Intermediate Code construction phase transforms EM into the
|
||||||
|
intermediate code (ic) of the optimizer
|
||||||
|
.IP CF
|
||||||
|
the Control Flow phase extends the ic with control flow
|
||||||
|
information and interprocedural information
|
||||||
|
.IP OPTs
|
||||||
|
zero or more optimization phases, each one performing one or
|
||||||
|
more related optimizations
|
||||||
|
.IP CA
|
||||||
|
the Compact Assembly phase generates Compact Assembly Language EM code
|
||||||
|
out of ic.
|
||||||
|
.LP
|
||||||
|
.PP
|
||||||
|
An important issue in the design of a global optimizer is the
|
||||||
|
interaction between optimization techniques.
|
||||||
|
It is often advantageous to combine several techniques in
|
||||||
|
one algorithm that takes into account all interactions between them.
|
||||||
|
Ideally, one single algorithm should be developed that does
|
||||||
|
all optimizations simultaneously and deals with all possible interactions.
|
||||||
|
In practice, such an algorithm is still far out of reach.
|
||||||
|
Instead some rather ad hoc (albeit important) combinations are chosen,
|
||||||
|
such as Common Subexpression Elimination and Register Allocation.
|
||||||
|
.[
|
||||||
|
prabhala sethi common subexpressions
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
sethi ullman optimal code
|
||||||
|
.]
|
||||||
|
.PP
|
||||||
|
In the Em Global Optimizer there is one separate algorithm for
|
||||||
|
every technique.
|
||||||
|
Note that this does not mean that all techniques are independent
|
||||||
|
of each other.
|
||||||
|
.PP
|
||||||
|
In principle, the optimization phases can be run in any order;
|
||||||
|
a phase may even be run more than once.
|
||||||
|
However, the following rules should be obeyed:
|
||||||
|
.IP -
|
||||||
|
the Live Variable analysis phase (LV) must be run prior to
|
||||||
|
Register Allocation (RA), as RA uses information outputted by LV.
|
||||||
|
.IP -
|
||||||
|
RA should be the last phase; this is a consequence of the way
|
||||||
|
the interface between RA and the Code Generator is defined.
|
||||||
|
.LP
|
||||||
|
The ordering of the phases has significant impact on
|
||||||
|
the quality of the produced code.
|
||||||
|
In
|
||||||
|
.[
|
||||||
|
wulf overview production quality carnegie-mellon
|
||||||
|
.]
|
||||||
|
two kinds of phase ordering problems are distinguished.
|
||||||
|
If two techniques A and B both take away opportunities of each other,
|
||||||
|
there is a "negative" ordering problem.
|
||||||
|
If, on the other hand, both A and B introduce new optimization
|
||||||
|
opportunities for each other, the problem is called "positive".
|
||||||
|
In the Global Optimizer the following interactions must be
|
||||||
|
taken into account:
|
||||||
|
.IP -
|
||||||
|
Inline Substitution (IL) may create new opportunities for most
|
||||||
|
other techniques, so it should be run as early as possible
|
||||||
|
.IP -
|
||||||
|
Use Definition analysis (UD) may introduce opportunities for LV.
|
||||||
|
.IP -
|
||||||
|
Strength Reduction may create opportunities for UD
|
||||||
|
.LP
|
||||||
|
The optimizer has a default phase ordering, which can
|
||||||
|
be changed by the user.
|
||||||
|
.NH 2
|
||||||
|
Structure of this document
|
||||||
|
.PP
|
||||||
|
The remaining chapters of this document each describe one
|
||||||
|
phase of the optimizer.
|
||||||
|
For every phase, we describe its task, its design,
|
||||||
|
its implementation, and its source files.
|
||||||
|
The latter two sections are intended to aid the
|
||||||
|
maintenance of the optimizer and
|
||||||
|
can be skipped by the initial reader.
|
||||||
|
.NH 2
|
||||||
|
References
|
||||||
|
.PP
|
||||||
|
There are very
|
||||||
|
few modern textbooks on optimization.
|
||||||
|
Chapters 12, 13, and 14 of
|
||||||
|
.[
|
||||||
|
aho compiler design
|
||||||
|
.]
|
||||||
|
are a good introduction to the subject.
|
||||||
|
Wulf et. al.
|
||||||
|
.[
|
||||||
|
wulf optimizing compiler
|
||||||
|
.]
|
||||||
|
describe one specific optimizing (Bliss) compiler.
|
||||||
|
Anklam et. al.
|
||||||
|
.[
|
||||||
|
anklam vax-11
|
||||||
|
.]
|
||||||
|
discuss code generation and optimization in
|
||||||
|
compilers for one specific machine (a Vax-11).
|
||||||
|
Kirchgaesner et. al.
|
||||||
|
.[
|
||||||
|
optimizing ada compiler
|
||||||
|
.]
|
||||||
|
present a brief description of many
|
||||||
|
optimizations; the report also contains a lengthy (over 60 pages)
|
||||||
|
bibliography.
|
||||||
|
.PP
|
||||||
|
The number of articles on optimization is quite impressive.
|
||||||
|
The Lowry and Medlock paper on the Fortran H compiler
|
||||||
|
.[
|
||||||
|
object code optimization Lowry Medlock
|
||||||
|
.]
|
||||||
|
is a classical one.
|
||||||
|
Other papers on global optimization are.
|
||||||
|
.[
|
||||||
|
faiman optimizing pascal
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
perkins sites
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
harrison general purpose optimizing
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
morel partial redundancies
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
Mintz global optimizer
|
||||||
|
.]
|
||||||
|
Freudenberger
|
||||||
|
.[
|
||||||
|
freudenberger setl optimizer
|
||||||
|
.]
|
||||||
|
describes an optimizer for a Very High Level Language (SETL).
|
||||||
|
The Production-Quality Compiler-Compiler (PQCC) project uses
|
||||||
|
very sophisticated compiler techniques, as described in.
|
||||||
|
.[
|
||||||
|
wulf overview ieee
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
wulf overview carnegie-mellon
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
wulf machine-relative
|
||||||
|
.]
|
||||||
|
.PP
|
||||||
|
Several Ph.D. theses are dedicated to optimization.
|
||||||
|
Davidson
|
||||||
|
.[
|
||||||
|
davidson simplifying
|
||||||
|
.]
|
||||||
|
outlines a machine-independent peephole optimizer that
|
||||||
|
improves assembly code.
|
||||||
|
Katkus
|
||||||
|
.[
|
||||||
|
katkus
|
||||||
|
.]
|
||||||
|
describes how efficient programs can be obtained at little cost by
|
||||||
|
optimizing only a small part of a program.
|
||||||
|
Photopoulos
|
||||||
|
.[
|
||||||
|
photopoulos mixed code
|
||||||
|
.]
|
||||||
|
discusses the idea of generating interpreted intermediate code as well
|
||||||
|
as assembly code, to obtain programs that are both small and fast.
|
||||||
|
Shaffer
|
||||||
|
.[
|
||||||
|
shaffer automatic
|
||||||
|
.]
|
||||||
|
describes the theory of automatic subroutine generation.
|
||||||
|
.]
|
||||||
|
Leverett
|
||||||
|
.[
|
||||||
|
leverett register allocation compilers
|
||||||
|
.]
|
||||||
|
deals with register allocation in the PQCC compilers.
|
||||||
|
.PP
|
||||||
|
References to articles about specific optimization techniques
|
||||||
|
will be given in later chapters.
|
||||||
64
doc/ego/proto.make
Normal file
64
doc/ego/proto.make
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
# $Id$
|
||||||
|
|
||||||
|
#PARAMS do not remove this line!
|
||||||
|
|
||||||
|
SRC_DIR = $(SRC_HOME)/doc/ego
|
||||||
|
|
||||||
|
REFS=-p $(SRC_DIR)/refs.opt -p $(SRC_DIR)/refs.stat -p $(SRC_DIR)/refs.gen
|
||||||
|
REFFILES = $(SRC_DIR)/refs.opt $(SRC_DIR)/refs.stat $(SRC_DIR)/refs.gen
|
||||||
|
INTRO=$(SRC_DIR)/intro/intro?
|
||||||
|
OV=$(SRC_DIR)/ov/ov?
|
||||||
|
IC=$(SRC_DIR)/ic/ic?
|
||||||
|
CF=$(SRC_DIR)/cf/cf?
|
||||||
|
IL=$(SRC_DIR)/il/il?
|
||||||
|
SR=$(SRC_DIR)/sr/sr?
|
||||||
|
CS=$(SRC_DIR)/cs/cs?
|
||||||
|
SP=$(SRC_DIR)/sp/sp?
|
||||||
|
UD=$(SRC_DIR)/ud/ud?
|
||||||
|
LV=$(SRC_DIR)/lv/lv?
|
||||||
|
CJ=$(SRC_DIR)/cj/cj?
|
||||||
|
BO=$(SRC_DIR)/bo/bo?
|
||||||
|
RA=$(SRC_DIR)/ra/ra?
|
||||||
|
CA=$(SRC_DIR)/ca/ca?
|
||||||
|
EGO=$(INTRO) $(OV) $(IC) $(CF) $(IL) $(SR) $(CS) $(SP) $(CJ) $(BO) \
|
||||||
|
$(UD) $(LV) $(RA) $(CA)
|
||||||
|
REFER=refer
|
||||||
|
TROFF=troff
|
||||||
|
TBL=tbl
|
||||||
|
TARGET=-Tlp
|
||||||
|
HEAD = $(SRC_DIR)/intro/head
|
||||||
|
TAIL = $(SRC_DIR)/intro/tail
|
||||||
|
|
||||||
|
$(TARGET_HOME)/doc/ego.doc: $(REFFILES) $(HEAD) $(TAIL) $(EGO)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(EGO) $(TAIL) | $(TBL) > $(TARGET_HOME)/doc/ego.doc
|
||||||
|
|
||||||
|
ego.f: $(REFFILES) $(HEAD) $(TAIL) $(EGO)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(EGO) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > ego.f
|
||||||
|
intro.f: $(REFFILES) $(HEAD) $(TAIL) $(INTRO)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(INTRO) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > intro.f
|
||||||
|
ov.f: $(REFFILES) $(HEAD) $(TAIL) $(OV)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(OV) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > ov.f
|
||||||
|
ic.f: $(REFFILES) $(HEAD) $(TAIL) $(IC)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(IC) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > ic.f
|
||||||
|
cf.f: $(REFFILES) $(HEAD) $(TAIL) $(CF)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(CF) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > cf.f
|
||||||
|
il.f: $(REFFILES) $(HEAD) $(TAIL) $(IL)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(IL) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > il.f
|
||||||
|
sr.f: $(REFFILES) $(HEAD) $(TAIL) $(SR)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(SR) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > sr.f
|
||||||
|
cs.f: $(REFFILES) $(HEAD) $(TAIL) $(CS)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(CS) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > cs.f
|
||||||
|
sp.f: $(REFFILES) $(HEAD) $(TAIL) $(SP)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(SP) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > sp.f
|
||||||
|
cj.f: $(REFFILES) $(HEAD) $(TAIL) $(CJ)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(CJ) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > cj.f
|
||||||
|
bo.f: $(REFFILES) $(HEAD) $(TAIL) $(BO)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(BO) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > bo.f
|
||||||
|
ud.f: $(REFFILES) $(HEAD) $(TAIL) $(UD)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(UD) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > ud.f
|
||||||
|
lv.f: $(REFFILES) $(HEAD) $(TAIL) $(LV)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(LV) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > lv.f
|
||||||
|
ra.f: $(REFFILES) $(HEAD) $(TAIL) $(RA)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(RA) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > ra.f
|
||||||
|
ca.f: $(REFFILES) $(HEAD) $(TAIL) $(CA)
|
||||||
|
$(REFER) -sA+T -l4,2 $(REFS) $(HEAD) $(CA) $(TAIL) | $(TBL) | $(TROFF) $(TARGET) -ms > ca.f
|
||||||
4
doc/ego/ra/.distr
Normal file
4
doc/ego/ra/.distr
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
ra1
|
||||||
|
ra2
|
||||||
|
ra3
|
||||||
|
ra4
|
||||||
33
doc/ego/ra/ra1
Normal file
33
doc/ego/ra/ra1
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
.bp
|
||||||
|
.NH 1
|
||||||
|
Register Allocation
|
||||||
|
.NH 2
|
||||||
|
Introduction
|
||||||
|
.PP
|
||||||
|
The efficient usage of the general purpose registers
|
||||||
|
of the target machine plays a key role in any optimizing compiler.
|
||||||
|
This subject, often referred to as \fIRegister Allocation\fR,
|
||||||
|
has great impact on both the code generator and the
|
||||||
|
optimizing part of such a compiler.
|
||||||
|
The code generator needs registers for at least the evaluation of
|
||||||
|
arithmetic expressions;
|
||||||
|
the optimizer uses the registers to decrease the access costs
|
||||||
|
of frequently used entities (such as variables).
|
||||||
|
The design of an optimizing compiler must pay great
|
||||||
|
attention to the cooperation of optimization, register allocation
|
||||||
|
and code generation.
|
||||||
|
.PP
|
||||||
|
Register allocation has received much attention in literature (see
|
||||||
|
.[
|
||||||
|
leverett register allocation compilers
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
chaitin register coloring
|
||||||
|
.]
|
||||||
|
.[
|
||||||
|
freiburghouse usage counts
|
||||||
|
.]
|
||||||
|
and
|
||||||
|
.[~[
|
||||||
|
sites register
|
||||||
|
.]]).
|
||||||
139
doc/ego/ra/ra2
Normal file
139
doc/ego/ra/ra2
Normal file
@ -0,0 +1,139 @@
|
|||||||
|
.NH 2
|
||||||
|
Usage of registers in ACK compilers
|
||||||
|
.PP
|
||||||
|
We will first describe the major design decisions
|
||||||
|
of the Amsterdam Compiler Kit,
|
||||||
|
as far as they concern register allocation.
|
||||||
|
Subsequently we will outline
|
||||||
|
the role of the Global Optimizer in the register
|
||||||
|
allocation process and the interface
|
||||||
|
between the code generator and the optimizer.
|
||||||
|
.NH 3
|
||||||
|
Usage of registers without the intervention of the Global Optimizer
|
||||||
|
.PP
|
||||||
|
Registers are used for two purposes:
|
||||||
|
.IP 1.
|
||||||
|
for the evaluation of arithmetic expressions
|
||||||
|
.IP 2.
|
||||||
|
to hold local variables, for the duration of the procedure they
|
||||||
|
are local to.
|
||||||
|
.LP
|
||||||
|
It is essential to note that no translation part of the compilers,
|
||||||
|
except for the code generator, knows anything at all
|
||||||
|
about the register set of the target computer.
|
||||||
|
Hence all decisions about registers are ultimately made by
|
||||||
|
the code generator.
|
||||||
|
Earlier phases of a compiler can only \fIadvise\fR the code generator.
|
||||||
|
.PP
|
||||||
|
The code generator splits the register set into two:
|
||||||
|
a fixed part for the evaluation of expressions (called \fIscratch\fR
|
||||||
|
registers) and a fixed part to store local variables.
|
||||||
|
This partitioning, which depends only on the target computer, significantly
|
||||||
|
reduces the complexity of register allocation, at the penalty
|
||||||
|
of some loss of code quality.
|
||||||
|
.PP
|
||||||
|
The code generator has some (machine-dependent) knowledge of the access costs
|
||||||
|
of memory locations and registers and of the costs of saving and
|
||||||
|
restoring registers. (Registers are always saved by the \fIcalled\fR
|
||||||
|
procedure).
|
||||||
|
This knowledge is expressed in a set of procedures for each target machine.
|
||||||
|
The code generator also knows how many registers there are and of
|
||||||
|
which type they are.
|
||||||
|
A register can be of type \fIpointer\fR, \fIfloating point\fR
|
||||||
|
or \fIgeneral\fR.
|
||||||
|
.PP
|
||||||
|
The front ends of the compilers determine which local variables may
|
||||||
|
be put in a register;
|
||||||
|
such a variable may never be accessed indirectly (i.e. through a pointer).
|
||||||
|
The front end also determines the types and sizes of these variables.
|
||||||
|
The type can be any of the register types or the type \fIloop variable\fR,
|
||||||
|
which denotes a general-typed variable that is used as loop variable
|
||||||
|
in a for-statement.
|
||||||
|
All this information is collected in a \fIregister message\fR in
|
||||||
|
the EM code.
|
||||||
|
Such a message is a pseudo EM instruction.
|
||||||
|
This message also contains a \fIscore\fR field,
|
||||||
|
indicating how desirable it is to put this variable in a register.
|
||||||
|
A front end may assign a high score to a variable if it
|
||||||
|
was declared as a register variable (which is only possible in
|
||||||
|
some languages, such as "C").
|
||||||
|
Any compiler phase before the code generator may change this score field,
|
||||||
|
if it has reason to do so.
|
||||||
|
The code generator bases its decisions on the information contained
|
||||||
|
in the register message, most notably on the score.
|
||||||
|
.PP
|
||||||
|
If the global optimizer is not used,
|
||||||
|
the score fields are set by the Peephole Optimizer.
|
||||||
|
This optimizer simply counts the number of occurrences
|
||||||
|
of every local (register) variable and adds this count
|
||||||
|
to the score provided by the front end.
|
||||||
|
In this way a simple, yet quite effective
|
||||||
|
register allocation scheme is achieved.
|
||||||
|
.NH 3
|
||||||
|
The role of the Global Optimizer
|
||||||
|
.PP
|
||||||
|
The Global Optimizer essentially tries to improve the scheme
|
||||||
|
outlined above.
|
||||||
|
It uses the following principles for this purpose:
|
||||||
|
.IP -
|
||||||
|
Entities are not always assigned a register for the duration
|
||||||
|
of an entire procedure; smaller regions of the program text
|
||||||
|
may be considered too.
|
||||||
|
.IP -
|
||||||
|
several variables may be put in the same register simultaneously,
|
||||||
|
provided at most one of them is live at any point.
|
||||||
|
.IP -
|
||||||
|
besides local variables, other entities (such as constants and addresses of
|
||||||
|
variables and procedures) may be put in a register.
|
||||||
|
.IP -
|
||||||
|
more accurate cost estimates are used.
|
||||||
|
.LP
|
||||||
|
To perform its task, the optimizer must have some
|
||||||
|
knowledge of the target machine.
|
||||||
|
.NH 3
|
||||||
|
The interface between the register allocator and the code generator
|
||||||
|
.PP
|
||||||
|
The RA phase of the optimizer must somehow be able to express its
|
||||||
|
decisions.
|
||||||
|
Such decisions may look like: 'put constant 1283 in a register from
|
||||||
|
line 12 to line 40'.
|
||||||
|
To be precise, RA must be able to tell the code generator to:
|
||||||
|
.IP -
|
||||||
|
initialize a register with some value
|
||||||
|
.IP -
|
||||||
|
update an entity from a register
|
||||||
|
.IP -
|
||||||
|
replace all occurrences of an entity in a certain region
|
||||||
|
of text by a reference to the register.
|
||||||
|
.LP
|
||||||
|
At least three problems occur here: the code generator is only used to
|
||||||
|
put local variables in registers,
|
||||||
|
it only assigns a register to a variable for the duration of an entire
|
||||||
|
procedure and it is not used to have some earlier compiler phase
|
||||||
|
make all the decisions.
|
||||||
|
.PP
|
||||||
|
All problems are solved by one mechanism, that involves no changes
|
||||||
|
to the code generator.
|
||||||
|
With every (non-scratch) register R that will be used in
|
||||||
|
a procedure P, we associate a new variable T, local to P.
|
||||||
|
The size of T is the same as the size of R.
|
||||||
|
A register message is generated for T with an exceptionally high score.
|
||||||
|
The scores of all original register messages are set to zero.
|
||||||
|
Consequently, the code generator will always assign precisely those new
|
||||||
|
variables to a register.
|
||||||
|
If the optimizer wants to put some entity, say the constant 1283, in
|
||||||
|
a register, it emits the code "T := 1283" and replaces all occurrences
|
||||||
|
of '1283' by T.
|
||||||
|
Similarly, it can put the address of a procedure in T and replace all
|
||||||
|
calls to that procedure by indirect calls.
|
||||||
|
Furthermore, it can put several different entities in T (and thus in R)
|
||||||
|
during the lifetime of P.
|
||||||
|
.PP
|
||||||
|
In principle, the code generated by the optimizer in this way would
|
||||||
|
always be valid EM code, even if the optimizer would be presented
|
||||||
|
a totally wrong description of the target computer register set.
|
||||||
|
In practice, it would be a waste of data as well as text space to
|
||||||
|
allocate memory for these new variables, as they will always be assigned
|
||||||
|
a register (in the correct order of events).
|
||||||
|
Hence, no memory locations are allocated for them.
|
||||||
|
For this reason they are called pseudo local variables.
|
||||||
386
doc/ego/ra/ra3
Normal file
386
doc/ego/ra/ra3
Normal file
@ -0,0 +1,386 @@
|
|||||||
|
.NH 2
|
||||||
|
The register allocation phase
|
||||||
|
.PP
|
||||||
|
.NH 3
|
||||||
|
Overview
|
||||||
|
.PP
|
||||||
|
The RA phase deals with one procedure at a time.
|
||||||
|
For every procedure, it first determines which entities
|
||||||
|
may be put in a register. Such an entity
|
||||||
|
is called an \fIitem\fR.
|
||||||
|
For every item it decides during which parts of the procedure it
|
||||||
|
might be assigned a register.
|
||||||
|
Such a region is called a \fItimespan\fR.
|
||||||
|
For any item, several (possibly overlapping) timespans may
|
||||||
|
be considered.
|
||||||
|
A pair (item,timespan) is called an \fIallocation\fR.
|
||||||
|
If the items of two allocations are both live at some
|
||||||
|
point of time in the intersections of their timespans,
|
||||||
|
these allocations are said to be \fIrivals\fR of each other,
|
||||||
|
as they cannot be assigned the same register.
|
||||||
|
The rivals-set of every allocation is computed.
|
||||||
|
Next, the gains of assigning a register to an allocation are estimated,
|
||||||
|
for every allocation.
|
||||||
|
With all this information, decisions are made which allocations
|
||||||
|
to store in which registers (\fIpacking\fR).
|
||||||
|
Finally, the EM text is transformed to reflect these decisions.
|
||||||
|
.NH 3
|
||||||
|
The item recognition subphase
|
||||||
|
.PP
|
||||||
|
RA tries to put the following entities in a register:
|
||||||
|
.IP -
|
||||||
|
a local variable for which a register message was found
|
||||||
|
.IP -
|
||||||
|
the address of a local variable for which no
|
||||||
|
register message was found
|
||||||
|
.IP -
|
||||||
|
the address of a global variable
|
||||||
|
.IP -
|
||||||
|
the address of a procedure
|
||||||
|
.IP -
|
||||||
|
a numeric constant.
|
||||||
|
.LP
|
||||||
|
Only the \fIaddress\fR of a global variable
|
||||||
|
may be put in a register, not the variable itself.
|
||||||
|
This approach avoids the very complex problems that would be
|
||||||
|
caused by procedure calls and indirect pointer references (see
|
||||||
|
.[~[
|
||||||
|
aho design compiler
|
||||||
|
.] sections 14.7 and 14.8]
|
||||||
|
and
|
||||||
|
.[~[
|
||||||
|
spillman side-effects
|
||||||
|
.]]).
|
||||||
|
Still, on most machines accessing a global variable using indirect
|
||||||
|
addressing through a register is much cheaper than
|
||||||
|
accessing it via its address.
|
||||||
|
Similarly, if the address of a procedure is put in a register, the
|
||||||
|
procedure can be called via an indirect call.
|
||||||
|
.PP
|
||||||
|
With every item we associate a register type.
|
||||||
|
This type is
|
||||||
|
.DS
|
||||||
|
for local variables: the type contained in the register message
|
||||||
|
for addresses of variables and procedures: the pointer type
|
||||||
|
for constants: the general type
|
||||||
|
.DE
|
||||||
|
An entity other than a local variable is not taken to be an item
|
||||||
|
if it is used only once within the current procedure.
|
||||||
|
.PP
|
||||||
|
An item is said to be \fIlive\fR at some point of the program text
|
||||||
|
if its value may be used before it is changed.
|
||||||
|
As addresses and constants are never changed, all items but local
|
||||||
|
variables are always live.
|
||||||
|
The region of text during which a local variable is live is
|
||||||
|
determined via the live/dead messages generated by the
|
||||||
|
Live Variable analysis phase of the Global Optimizer.
|
||||||
|
.NH 3
|
||||||
|
The allocation determination subphase
|
||||||
|
.PP
|
||||||
|
If a procedure has more items than registers,
|
||||||
|
it may be advantageous to put an item in a register
|
||||||
|
only during those parts of the procedure where it is most
|
||||||
|
heavily used.
|
||||||
|
Such a part will be called a timespan.
|
||||||
|
With every item we may associate a set of timespans.
|
||||||
|
If two timespans of an item overlap,
|
||||||
|
at most one of them may be granted a register,
|
||||||
|
as there is no use in putting the same item in two
|
||||||
|
registers simultaneously.
|
||||||
|
If two timespans of an item are distinct,
|
||||||
|
both may be chosen;
|
||||||
|
the item will possibly be put in two
|
||||||
|
different registers during different parts of the procedure.
|
||||||
|
The timespan may also consist
|
||||||
|
of the whole procedure.
|
||||||
|
.PP
|
||||||
|
A list of (item,timespan) pairs (allocations)
|
||||||
|
is build, which will be the input to the decision making
|
||||||
|
subphase of RA (packing subphase).
|
||||||
|
This allocation list is the main data structure of RA.
|
||||||
|
The description of the remainder of RA will be in terms
|
||||||
|
of allocations rather than items.
|
||||||
|
The phrase "to assign a register to an allocation" means "to assign
|
||||||
|
a register to the item of the allocation for the duration of
|
||||||
|
the timespan of the allocation".
|
||||||
|
Subsequent subphases will add more information
|
||||||
|
to this list.
|
||||||
|
.PP
|
||||||
|
Several factors must be taken into account when a
|
||||||
|
timespan for an item is constructed:
|
||||||
|
.IP 1.
|
||||||
|
At any \fIentry point\fR of the timespan where the
|
||||||
|
item is live,
|
||||||
|
the register must be initialized with the item
|
||||||
|
.IP 2.
|
||||||
|
At any exit point of the timespan where the item is live,
|
||||||
|
the item must be updated.
|
||||||
|
.LP
|
||||||
|
In order to decrease these costs, we will only consider timespans with
|
||||||
|
one entry point
|
||||||
|
and no live exit points.
|
||||||
|
.NH 3
|
||||||
|
The rivals computation subphase
|
||||||
|
.PP
|
||||||
|
As stated before, several different items may be put in the
|
||||||
|
same register, provided they are not live simultaneously.
|
||||||
|
For every allocation we determine the intersection
|
||||||
|
of its timespan and the lifetime of its item (i.e. the part of the
|
||||||
|
procedure during which the item is live).
|
||||||
|
The allocation is said to be busy during this intersection.
|
||||||
|
If two allocations are ever busy simultaneously they are
|
||||||
|
said to be rivals of each other.
|
||||||
|
The rivals information is added to the allocation list.
|
||||||
|
.NH 3
|
||||||
|
The profits computation subphase
|
||||||
|
.PP
|
||||||
|
To make good decisions, the packing subphase needs to
|
||||||
|
know which allocations can be assigned the same register
|
||||||
|
(rivals information) and how much is gained by
|
||||||
|
granting an allocation a register.
|
||||||
|
.PP
|
||||||
|
Besides the gains of using a register instead of an
|
||||||
|
item,
|
||||||
|
two kinds of overhead costs must be
|
||||||
|
taken into account:
|
||||||
|
.IP -
|
||||||
|
the register must be initialized with the item
|
||||||
|
.IP -
|
||||||
|
the register must be saved at procedure entry
|
||||||
|
and restored at procedure exit.
|
||||||
|
.LP
|
||||||
|
The latter costs should not be due to a single
|
||||||
|
allocation, as several allocations can be assigned the same register.
|
||||||
|
These costs are dealt with after packing has been done.
|
||||||
|
They do not influence the decisions of the packing algorithm,
|
||||||
|
they may only undo them.
|
||||||
|
.PP
|
||||||
|
The actual profits consist of improvements
|
||||||
|
of execution time and code size.
|
||||||
|
As the former is far more difficult to estimate , we will
|
||||||
|
discuss code size improvements first.
|
||||||
|
.PP
|
||||||
|
The gains of putting a certain item in a register
|
||||||
|
depends on how the item is used.
|
||||||
|
Suppose the item is
|
||||||
|
a pointer variable.
|
||||||
|
On machines that do not have a
|
||||||
|
double-indirect addressing mode,
|
||||||
|
two instructions are needed to dereference the variable
|
||||||
|
if it is not in a register, but only one if it is put in a register.
|
||||||
|
If the variable is not dereferenced, but simply copied, one instruction
|
||||||
|
may be sufficient in both cases.
|
||||||
|
So the gains of putting a pointer variable in a register are higher
|
||||||
|
if the variable is dereferenced often.
|
||||||
|
.PP
|
||||||
|
To make accurate estimates, detailed knowledge of
|
||||||
|
the target machine and of the code generator
|
||||||
|
would be needed.
|
||||||
|
Therefore, a simplification has been made that substantially limits
|
||||||
|
the amount of target machine information that is needed.
|
||||||
|
The estimation of the number of bytes saved does
|
||||||
|
not take into account how an item is used.
|
||||||
|
Rather, an average number is used.
|
||||||
|
So these gains are computed as follows:
|
||||||
|
.DS
|
||||||
|
#bytes_saved = #occurrences * gains_per_occurrence
|
||||||
|
.DE
|
||||||
|
The number of occurrences is derived from
|
||||||
|
the EM code.
|
||||||
|
Note that this is not exact either,
|
||||||
|
as there is no one-to-one correspondence between occurrences in
|
||||||
|
the EM code and in the assembler code.
|
||||||
|
.PP
|
||||||
|
The gains of one occurrence depend on:
|
||||||
|
.IP 1.
|
||||||
|
the type of the item
|
||||||
|
.IP 2.
|
||||||
|
the size of the item
|
||||||
|
.IP 3.
|
||||||
|
the type of the register
|
||||||
|
.LP
|
||||||
|
and for local variables and addresses of local variables:
|
||||||
|
.IP 4.
|
||||||
|
the type of the local variable
|
||||||
|
.IP 5.
|
||||||
|
the offset of the variable in the stackframe
|
||||||
|
.LP
|
||||||
|
For every allocation we try two types of registers: the register type
|
||||||
|
of the item and the general register type.
|
||||||
|
Only the type with the highest profits will subsequently be used.
|
||||||
|
This type is added to the allocation information.
|
||||||
|
.PP
|
||||||
|
To compute the gains, RA uses a machine-dependent table
|
||||||
|
that is read from a machine descriptor file.
|
||||||
|
By means of this table the number of bytes saved can be computed
|
||||||
|
as a function of the five properties.
|
||||||
|
.PP
|
||||||
|
The costs of initializing a register with an item
|
||||||
|
is determined in a similar way.
|
||||||
|
The cost of one initialization is also
|
||||||
|
obtained from the descriptor file.
|
||||||
|
Note that there can be at most one initialization for any
|
||||||
|
allocation.
|
||||||
|
.PP
|
||||||
|
To summarize, the number of bytes a certain allocation would
|
||||||
|
save is computed as follows:
|
||||||
|
.DS
|
||||||
|
.TS
|
||||||
|
l l.
|
||||||
|
net_bytes_saved = bytes_saved - init_cost
|
||||||
|
bytes_saved = #occurrences * gains_per_occ
|
||||||
|
init_cost = #initializations * costs_per_init
|
||||||
|
.TE
|
||||||
|
.DE
|
||||||
|
.PP
|
||||||
|
It is inherently more difficult to estimate the execution
|
||||||
|
time saved by putting an item in a register,
|
||||||
|
because it is impossible to predict how
|
||||||
|
many times an item will be used dynamically.
|
||||||
|
If an occurrence is part of a loop,
|
||||||
|
it may be executed many times.
|
||||||
|
If it is part of a conditional statement,
|
||||||
|
it may never be executed at all.
|
||||||
|
In the latter case, the speed of the program may even get
|
||||||
|
worse if an initialization is needed.
|
||||||
|
As a clear example, consider the piece of "C" code in Fig. 13.1.
|
||||||
|
.DS
|
||||||
|
switch(expr) {
|
||||||
|
case 1: p(); break;
|
||||||
|
case 2: p(); p(); break;
|
||||||
|
case 3: p(); break;
|
||||||
|
default: break;
|
||||||
|
}
|
||||||
|
|
||||||
|
Fig. 13.1 A "C" switch statement
|
||||||
|
.DE
|
||||||
|
Lots of bytes may be saved by putting the address of procedure p
|
||||||
|
in a register, as p is called four times (statically).
|
||||||
|
Dynamically, p will be called zero, one or two times,
|
||||||
|
depending on the value of the expression.
|
||||||
|
.PP
|
||||||
|
The optimizer uses the following strategy for optimizing
|
||||||
|
execution time:
|
||||||
|
.IP 1.
|
||||||
|
try to put items in registers during \fIloops\fR first
|
||||||
|
.IP 2.
|
||||||
|
always keep the initializing code outside the loop
|
||||||
|
.IP 3.
|
||||||
|
if an item is not used in a loop, do not put it in a register if
|
||||||
|
the initialization costs may be higher than the gains
|
||||||
|
.LP
|
||||||
|
The latter condition can be checked by determining the
|
||||||
|
minimal number of usages (dynamically) of the item during the procedure,
|
||||||
|
via a shortest path algorithm.
|
||||||
|
In the example above, this minimal number is zero, so the address of
|
||||||
|
p is not put in a register.
|
||||||
|
.PP
|
||||||
|
The costs of one occurrence is estimated as described above for the
|
||||||
|
code size.
|
||||||
|
The number of dynamic occurrences is guessed by looking at the
|
||||||
|
loop nesting level of every occurrence.
|
||||||
|
If the item is never used in a loop,
|
||||||
|
the minimal number of occurrences is used.
|
||||||
|
From these facts, the execution time improvement is assessed
|
||||||
|
for every allocation.
|
||||||
|
.NH 3
|
||||||
|
The packing subphase
|
||||||
|
.PP
|
||||||
|
The packing subphase takes as input the allocation
|
||||||
|
list and outputs a
|
||||||
|
description of which allocations should be put
|
||||||
|
in which registers.
|
||||||
|
So it is essentially the decision making part of RA.
|
||||||
|
.PP
|
||||||
|
The packing system tries to assign a register to allocations one
|
||||||
|
at a time, in some yet to be defined order.
|
||||||
|
For every allocation A, it first checks if there is a register
|
||||||
|
(of the right type)
|
||||||
|
that is already assigned to one or more allocations,
|
||||||
|
none of which are rivals of A.
|
||||||
|
In this case A is assigned the same register.
|
||||||
|
Else, A is assigned a new register, if one exists.
|
||||||
|
A table containing the number of free registers for every type
|
||||||
|
is maintained.
|
||||||
|
It is initialized with the number of non-scratch registers of
|
||||||
|
the target computer and updated whenever a
|
||||||
|
new register is handed out.
|
||||||
|
The packing algorithm stops when no more allocations can
|
||||||
|
or need be assigned a register.
|
||||||
|
.PP
|
||||||
|
After an allocation A has been packed,
|
||||||
|
all allocations with non-disjunct timespans (including
|
||||||
|
A itself) are removed from the allocation list.
|
||||||
|
.PP
|
||||||
|
In case the number of items exceeds the number of registers, it
|
||||||
|
is important to choose the most profitable allocations.
|
||||||
|
Due to the possibility of having several allocations
|
||||||
|
occupying the same register,
|
||||||
|
this problem is quite complex.
|
||||||
|
Our packing algorithm uses simple heuristic rules
|
||||||
|
and avoids any combinatorial search.
|
||||||
|
It has distinct rules for different costs measures.
|
||||||
|
.PP
|
||||||
|
If object code size is the most important factor,
|
||||||
|
the algorithm is greedy and chooses allocations in
|
||||||
|
decreasing order of their profits attribute.
|
||||||
|
It does not take into account the fact that
|
||||||
|
other allocations may be passed over because of
|
||||||
|
this decision.
|
||||||
|
.PP
|
||||||
|
If execution time is at prime stake, the algorithm
|
||||||
|
first considers allocations whose timespans consist of loops.
|
||||||
|
After all these have been packed, it considers the remaining
|
||||||
|
allocations.
|
||||||
|
Within the two subclasses, it considers allocations
|
||||||
|
with the highest profits first.
|
||||||
|
When assigning a register to an allocation with a loop
|
||||||
|
as timespan, the algorithm checks if the item has
|
||||||
|
already been put in a register during another loop.
|
||||||
|
If so, it tries to use the same register for the
|
||||||
|
new allocation.
|
||||||
|
After all packing has been done,
|
||||||
|
it checks if the item has always been assigned the same
|
||||||
|
register (although not necessarily during all loops).
|
||||||
|
If so, it tries to put the item in that register during
|
||||||
|
the entire procedure. This is possible
|
||||||
|
if the allocation (item,whole_procedure) is not a rival
|
||||||
|
of any allocation with a different item that has been
|
||||||
|
assigned to the same register.
|
||||||
|
Note that this approach is essentially 'bottom up',
|
||||||
|
as registers are first assigned over small regions
|
||||||
|
of text which are later collapsed into larger regions.
|
||||||
|
The advantage of this approach is the fact that
|
||||||
|
the decisions for one loop can be made independently
|
||||||
|
of all other loops.
|
||||||
|
.PP
|
||||||
|
After the entire packing process has been completed,
|
||||||
|
we compute for each register how much is gained in using
|
||||||
|
this register, by simply adding the net profits
|
||||||
|
of all allocations assigned to it.
|
||||||
|
This total yield should outweigh the costs of
|
||||||
|
saving/restoring the register at procedure entry/exit.
|
||||||
|
As most modern processors (e.g. 68000, Vax) have special
|
||||||
|
instructions to save/restore several registers,
|
||||||
|
the differential costs of saving one extra register are by
|
||||||
|
no means constant.
|
||||||
|
The costs are read from the machine descriptor file and
|
||||||
|
compared to the total yields of the registers.
|
||||||
|
As a consequence of this analysis, some allocations
|
||||||
|
may have their registers taken away.
|
||||||
|
.NH 3
|
||||||
|
The transformation subphase
|
||||||
|
.PP
|
||||||
|
The final subphase of RA transforms the EM text according to the
|
||||||
|
decisions made by the packing system.
|
||||||
|
It traverses the text of the currently optimized procedure and
|
||||||
|
changes all occurrences of items at points where
|
||||||
|
they are assigned a register.
|
||||||
|
It also clears the score field of the register messages for
|
||||||
|
normal local variables and emits register messages with a very
|
||||||
|
high score for the pseudo locals.
|
||||||
|
At points where registers have to be initialized with items,
|
||||||
|
it generates EM code to do so.
|
||||||
|
Finally it tries to decrease the size of the stackframe
|
||||||
|
of the procedure by looking at which local variables need not
|
||||||
|
be given memory locations.
|
||||||
28
doc/ego/ra/ra4
Normal file
28
doc/ego/ra/ra4
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
.NH 2
|
||||||
|
Source files of RA
|
||||||
|
.PP
|
||||||
|
The sources of RA are in the following files and packages:
|
||||||
|
.IP ra.h: 14
|
||||||
|
declarations of global variables and data structures
|
||||||
|
.IP ra.c:
|
||||||
|
the routine main; initialization of target machine-dependent tables
|
||||||
|
.IP items:
|
||||||
|
a routine to build the list of items of one procedure;
|
||||||
|
routines to manipulate items
|
||||||
|
.IP lifetime:
|
||||||
|
contains a subroutine that determines when items are live/dead
|
||||||
|
.IP alloclist:
|
||||||
|
contains subroutines that build the initial allocations list
|
||||||
|
and that compute the rivals sets.
|
||||||
|
.IP profits:
|
||||||
|
contains a subroutine that computes the profits of the allocations
|
||||||
|
and a routine that determines the costs of saving/restoring registers
|
||||||
|
.IP pack:
|
||||||
|
contains the packing subphase
|
||||||
|
.IP xform:
|
||||||
|
contains the transformation subphase
|
||||||
|
.IP interval:
|
||||||
|
contains routines to manipulate intervals of time
|
||||||
|
.IP aux:
|
||||||
|
contains auxiliary routines
|
||||||
|
.LP
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user