mkarmreg.pp 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317
  1. {
  2. $Id$
  3. Copyright (c) 1998-2002 by Peter Vreman and Florian Klaempfl
  4. Convert spreg.dat to several .inc files for usage with
  5. the Free pascal compiler
  6. See the file COPYING.FPC, included in this distribution,
  7. for details about the copyright.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  11. **********************************************************************}
  12. program mkspreg;
  13. const Version = '1.00';
  14. max_regcount = 200;
  15. var s : string;
  16. i : longint;
  17. line : longint;
  18. regcount:byte;
  19. regcount_bsstart:byte;
  20. names,
  21. regtypes,
  22. supregs,
  23. numbers,
  24. stdnames,
  25. stabs,dwarf : array[0..max_regcount-1] of string[63];
  26. regnumber_index,
  27. std_regname_index : array[0..max_regcount-1] of byte;
  28. {$ifndef FPC}
  29. procedure readln(var t:text;var s:string);
  30. var
  31. c : char;
  32. i : longint;
  33. begin
  34. c:=#0;
  35. i:=0;
  36. while (not eof(t)) and (c<>#10) do
  37. begin
  38. read(t,c);
  39. if c<>#10 then
  40. begin
  41. inc(i);
  42. s[i]:=c;
  43. end;
  44. end;
  45. if (i>0) and (s[i]=#13) then
  46. dec(i);
  47. s[0]:=chr(i);
  48. end;
  49. {$endif}
  50. function tostr(l : longint) : string;
  51. begin
  52. str(l,tostr);
  53. end;
  54. function readstr : string;
  55. var
  56. result : string;
  57. begin
  58. result:='';
  59. while (s[i]<>',') and (i<=length(s)) do
  60. begin
  61. result:=result+s[i];
  62. inc(i);
  63. end;
  64. readstr:=result;
  65. end;
  66. procedure readcomma;
  67. begin
  68. if s[i]<>',' then
  69. begin
  70. writeln('Missing "," at line ',line);
  71. writeln('Line: "',s,'"');
  72. halt(1);
  73. end;
  74. inc(i);
  75. end;
  76. procedure skipspace;
  77. begin
  78. while (s[i] in [' ',#9]) do
  79. inc(i);
  80. end;
  81. procedure openinc(var f:text;const fn:string);
  82. begin
  83. writeln('creating ',fn);
  84. assign(f,fn);
  85. rewrite(f);
  86. writeln(f,'{ don''t edit, this file is generated from armreg.dat }');
  87. end;
  88. procedure closeinc(var f:text);
  89. begin
  90. writeln(f);
  91. close(f);
  92. end;
  93. procedure build_regnum_index;
  94. var h,i,j,p,t:byte;
  95. begin
  96. {Build the registernumber2regindex index.
  97. Step 1: Fill.}
  98. for i:=0 to regcount-1 do
  99. regnumber_index[i]:=i;
  100. {Step 2: Sort. We use a Shell-Metzner sort.}
  101. p:=regcount_bsstart;
  102. repeat
  103. for h:=0 to regcount-p-1 do
  104. begin
  105. i:=h;
  106. repeat
  107. j:=i+p;
  108. if numbers[regnumber_index[j]]>=numbers[regnumber_index[i]] then
  109. break;
  110. t:=regnumber_index[i];
  111. regnumber_index[i]:=regnumber_index[j];
  112. regnumber_index[j]:=t;
  113. if i<p then
  114. break;
  115. dec(i,p);
  116. until false;
  117. end;
  118. p:=p shr 1;
  119. until p=0;
  120. end;
  121. procedure build_std_regname_index;
  122. var h,i,j,p,t:byte;
  123. begin
  124. {Build the registernumber2regindex index.
  125. Step 1: Fill.}
  126. for i:=0 to regcount-1 do
  127. std_regname_index[i]:=i;
  128. {Step 2: Sort. We use a Shell-Metzner sort.}
  129. p:=regcount_bsstart;
  130. repeat
  131. for h:=0 to regcount-p-1 do
  132. begin
  133. i:=h;
  134. repeat
  135. j:=i+p;
  136. if stdnames[std_regname_index[j]]>=stdnames[std_regname_index[i]] then
  137. break;
  138. t:=std_regname_index[i];
  139. std_regname_index[i]:=std_regname_index[j];
  140. std_regname_index[j]:=t;
  141. if i<p then
  142. break;
  143. dec(i,p);
  144. until false;
  145. end;
  146. p:=p shr 1;
  147. until p=0;
  148. end;
  149. procedure read_spreg_file;
  150. var infile:text;
  151. begin
  152. { open dat file }
  153. assign(infile,'armreg.dat');
  154. reset(infile);
  155. while not(eof(infile)) do
  156. begin
  157. { handle comment }
  158. readln(infile,s);
  159. inc(line);
  160. while (s[1]=' ') do
  161. delete(s,1,1);
  162. if (s='') or (s[1]=';') then
  163. continue;
  164. i:=1;
  165. names[regcount]:=readstr;
  166. readcomma;
  167. regtypes[regcount]:=readstr;
  168. readcomma;
  169. supregs[regcount]:=readstr;
  170. readcomma;
  171. stdnames[regcount]:=readstr;
  172. readcomma;
  173. stabs[regcount]:=readstr;
  174. readcomma;
  175. dwarf[regcount]:=readstr;
  176. { Create register number }
  177. if supregs[regcount][1]<>'$' then
  178. begin
  179. writeln('Missing $ before number, at line ',line);
  180. writeln('Line: "',s,'"');
  181. halt(1);
  182. end;
  183. numbers[regcount]:=regtypes[regcount]+'0000'+copy(supregs[regcount],2,255);
  184. if i<length(s) then
  185. begin
  186. writeln('Extra chars at end of line, at line ',line);
  187. writeln('Line: "',s,'"');
  188. halt(1);
  189. end;
  190. inc(regcount);
  191. if regcount>max_regcount then
  192. begin
  193. writeln('Error: Too much registers, please increase maxregcount in source');
  194. halt(2);
  195. end;
  196. end;
  197. close(infile);
  198. end;
  199. procedure write_inc_files;
  200. var
  201. norfile,stdfile,supfile,
  202. numfile,stabfile,dwarffile,confile,
  203. rnifile,srifile:text;
  204. first:boolean;
  205. begin
  206. { create inc files }
  207. openinc(confile,'rarmcon.inc');
  208. openinc(supfile,'rarmsup.inc');
  209. openinc(numfile,'rarmnum.inc');
  210. openinc(stdfile,'rarmstd.inc');
  211. openinc(stabfile,'rarmsta.inc');
  212. openinc(dwarffile,'rarmdwa.inc');
  213. openinc(norfile,'rarmnor.inc');
  214. openinc(rnifile,'rarmrni.inc');
  215. openinc(srifile,'rarmsri.inc');
  216. first:=true;
  217. for i:=0 to regcount-1 do
  218. begin
  219. if not first then
  220. begin
  221. writeln(numfile,',');
  222. writeln(stdfile,',');
  223. writeln(stabfile,',');
  224. writeln(dwarffile,',');
  225. writeln(rnifile,',');
  226. writeln(srifile,',');
  227. end
  228. else
  229. first:=false;
  230. writeln(supfile,'RS_',names[i],' = ',supregs[i],';');
  231. writeln(confile,'NR_'+names[i],' = ','tregister(',numbers[i],')',';');
  232. write(numfile,'tregister(',numbers[i],')');
  233. write(stdfile,'''',stdnames[i],'''');
  234. write(stabfile,stabs[i]);
  235. write(dwarffile,dwarf[i]);
  236. write(rnifile,regnumber_index[i]);
  237. write(srifile,std_regname_index[i]);
  238. end;
  239. write(norfile,regcount);
  240. close(confile);
  241. close(supfile);
  242. closeinc(numfile);
  243. closeinc(stdfile);
  244. closeinc(stabfile);
  245. closeinc(dwarffile);
  246. closeinc(norfile);
  247. closeinc(rnifile);
  248. closeinc(srifile);
  249. writeln('Done!');
  250. writeln(regcount,' registers procesed');
  251. end;
  252. begin
  253. writeln('Register Table Converter Version ',Version);
  254. line:=0;
  255. regcount:=0;
  256. read_spreg_file;
  257. regcount_bsstart:=1;
  258. while 2*regcount_bsstart<regcount do
  259. regcount_bsstart:=regcount_bsstart*2;
  260. build_regnum_index;
  261. build_std_regname_index;
  262. write_inc_files;
  263. end.
  264. {
  265. $Log$
  266. Revision 1.4 2004-06-16 20:07:11 florian
  267. * dwarf branch merged
  268. Revision 1.3.2.1 2004/06/12 17:01:01 florian
  269. * fixed compilation of arm compiler
  270. Revision 1.3 2003/12/18 17:06:21 florian
  271. * arm compiler compilation fixed
  272. Revision 1.2 2003/09/03 20:35:06 peter
  273. * fixed number sorting
  274. Revision 1.1 2003/09/03 19:09:35 florian
  275. * inital revision derived from sparc
  276. }