You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

460 lines
24KB

  1. --
  2. -- Definition of a dual port ROM for KCPSM2 or KCPSM3 program defined by progctrl.psm
  3. -- and assmbled using KCPSM2 or KCPSM3 assembler.
  4. --
  5. -- Standard IEEE libraries
  6. --
  7. library IEEE;
  8. use IEEE.STD_LOGIC_1164.ALL;
  9. use IEEE.STD_LOGIC_ARITH.ALL;
  10. use IEEE.STD_LOGIC_UNSIGNED.ALL;
  11. --
  12. -- The Unisim Library is used to define Xilinx primitives. It is also used during
  13. -- simulation. The source can be viewed at %XILINX%\vhdl\src\unisims\unisim_VCOMP.vhd
  14. --
  15. library unisim;
  16. use unisim.vcomponents.all;
  17. --
  18. --
  19. entity progctrl is
  20. Port ( address : in std_logic_vector(9 downto 0);
  21. instruction : out std_logic_vector(17 downto 0);
  22. proc_reset : out std_logic;
  23. clk : in std_logic);
  24. end progctrl;
  25. --
  26. architecture low_level_definition of progctrl is
  27. --
  28. -- Declare signals internal to this module
  29. --
  30. signal jaddr : std_logic_vector(10 downto 0);
  31. signal jparity : std_logic_vector(0 downto 0);
  32. signal jdata : std_logic_vector(7 downto 0);
  33. signal doa : std_logic_vector(7 downto 0);
  34. signal dopa : std_logic_vector(0 downto 0);
  35. signal tdo1 : std_logic;
  36. signal tdo2 : std_logic;
  37. signal update : std_logic;
  38. signal shift : std_logic;
  39. signal reset : std_logic;
  40. signal tdi : std_logic;
  41. signal sel1 : std_logic;
  42. signal drck1 : std_logic;
  43. signal drck1_buf : std_logic;
  44. signal sel2 : std_logic;
  45. signal drck2 : std_logic;
  46. signal capture : std_logic;
  47. signal tap5 : std_logic;
  48. signal tap11 : std_logic;
  49. signal tap17 : std_logic;
  50. --
  51. -- Attributes to define ROM contents during implementation synthesis.
  52. -- The information is repeated in the generic map for functional simulation
  53. --
  54. attribute INIT_00 : string;
  55. attribute INIT_01 : string;
  56. attribute INIT_02 : string;
  57. attribute INIT_03 : string;
  58. attribute INIT_04 : string;
  59. attribute INIT_05 : string;
  60. attribute INIT_06 : string;
  61. attribute INIT_07 : string;
  62. attribute INIT_08 : string;
  63. attribute INIT_09 : string;
  64. attribute INIT_0A : string;
  65. attribute INIT_0B : string;
  66. attribute INIT_0C : string;
  67. attribute INIT_0D : string;
  68. attribute INIT_0E : string;
  69. attribute INIT_0F : string;
  70. attribute INIT_10 : string;
  71. attribute INIT_11 : string;
  72. attribute INIT_12 : string;
  73. attribute INIT_13 : string;
  74. attribute INIT_14 : string;
  75. attribute INIT_15 : string;
  76. attribute INIT_16 : string;
  77. attribute INIT_17 : string;
  78. attribute INIT_18 : string;
  79. attribute INIT_19 : string;
  80. attribute INIT_1A : string;
  81. attribute INIT_1B : string;
  82. attribute INIT_1C : string;
  83. attribute INIT_1D : string;
  84. attribute INIT_1E : string;
  85. attribute INIT_1F : string;
  86. attribute INIT_20 : string;
  87. attribute INIT_21 : string;
  88. attribute INIT_22 : string;
  89. attribute INIT_23 : string;
  90. attribute INIT_24 : string;
  91. attribute INIT_25 : string;
  92. attribute INIT_26 : string;
  93. attribute INIT_27 : string;
  94. attribute INIT_28 : string;
  95. attribute INIT_29 : string;
  96. attribute INIT_2A : string;
  97. attribute INIT_2B : string;
  98. attribute INIT_2C : string;
  99. attribute INIT_2D : string;
  100. attribute INIT_2E : string;
  101. attribute INIT_2F : string;
  102. attribute INIT_30 : string;
  103. attribute INIT_31 : string;
  104. attribute INIT_32 : string;
  105. attribute INIT_33 : string;
  106. attribute INIT_34 : string;
  107. attribute INIT_35 : string;
  108. attribute INIT_36 : string;
  109. attribute INIT_37 : string;
  110. attribute INIT_38 : string;
  111. attribute INIT_39 : string;
  112. attribute INIT_3A : string;
  113. attribute INIT_3B : string;
  114. attribute INIT_3C : string;
  115. attribute INIT_3D : string;
  116. attribute INIT_3E : string;
  117. attribute INIT_3F : string;
  118. attribute INITP_00 : string;
  119. attribute INITP_01 : string;
  120. attribute INITP_02 : string;
  121. attribute INITP_03 : string;
  122. attribute INITP_04 : string;
  123. attribute INITP_05 : string;
  124. attribute INITP_06 : string;
  125. attribute INITP_07 : string;
  126. --
  127. -- Attributes to define ROM contents during implementation synthesis.
  128. --
  129. attribute INIT_00 of ram_1024_x_18 : label is "502C4042502A4045002201310F3E019301930193023301990193C001011A0027";
  130. attribute INIT_01 of ram_1024_x_18 : label is "013101310F3F019350D540535003404850C2404950A34052508C405750474050";
  131. attribute INIT_02 of ram_1024_x_18 : label is "011F02D401930904402D09FEA000C0080006A000013E10F00131011F40070131";
  132. attribute INIT_03 of ram_1024_x_18 : label is "02F14007022C5C38C902004101310F2E07000800019302090193543F4F590131";
  133. attribute INIT_04 of ram_1024_x_18 : label is "B0004B01006700574007022C004C01E20193A00000F700EA01D000EA01204007";
  134. attribute INIT_05 of ram_1024_x_18 : label is "B0004F0AB0004F0D011F54584F3A011F0E2B404C00776A2B0193016D504C4B04";
  135. attribute INIT_06 of ram_1024_x_18 : label is "8D02B4004B0450724B007BD08D037CD00D2B405B8E01F0E0017412F0011F13F0";
  136. attribute INIT_07 of ram_1024_x_18 : label is "032F00EAC10111A05077208000E000EA01E8A00078D0CD0177D0CD01A00079D0";
  137. attribute INIT_08 of ram_1024_x_18 : label is "1900588C018D02FEA00000F700EA01D05480CA018301A900A800870100EA7130";
  138. attribute INIT_09 of ram_1024_x_18 : label is "110000EA01404007022C0193009D5896018D030E1700588C018D1800588C018D";
  139. attribute INIT_0A of ram_1024_x_18 : label is "022C00B10193170058A3018D180058A3018D190058A3018D02FEA00000F700EA";
  140. attribute INIT_0B of ram_1024_x_18 : label is "54B2C60154B6C5010167A900A800870100E0019605100196016D019306104007";
  141. attribute INIT_0C of ram_1024_x_18 : label is "07020196016700E000EA0190070008000900019601310F3D02C60193A0000193";
  142. attribute INIT_0D of ram_1024_x_18 : label is "400700F40193016700E0019300EA0170070008000900400700F40193016700E0";
  143. attribute INIT_0E of ram_1024_x_18 : label is "C1080100C110C720C840C980A000C108400201060106C1080105C720C840C980";
  144. attribute INIT_0F of ram_1024_x_18 : label is "A00000F450F9208000E0AE008D010D000E00A00000EA01FFA000C10801060106";
  145. attribute INIT_10 of ram_1024_x_18 : label is "A000550CC10101070128A0005508C001000BA0000193016710D0016710E00193";
  146. attribute INIT_11 of ram_1024_x_18 : label is "C000A000551BC40101150414A0005516C30101100314A0005511C201010B0219";
  147. attribute INIT_12 of ram_1024_x_18 : label is "51204F114F014129552D20084000A000C00151294F134F014120552420084000";
  148. attribute INIT_13 of ram_1024_x_18 : label is "B8004061A000803AC1015D38C00A81010130A000CF0441315135200140004129";
  149. attribute INIT_14 of ram_1024_x_18 : label is "02069200020602061200B80001447010A000C0F6B80080C6A000A0DFBC00407B";
  150. attribute INIT_15 of ram_1024_x_18 : label is "0162A00F101012000162000E000E000E000E1100A0009200B800014470108101";
  151. attribute INIT_16 of ram_1024_x_18 : label is "108001671090A00001311F1001311F200156A000803A80075965C00AA0001100";
  152. attribute INIT_17 of ram_1024_x_18 : label is "D030B8000181102003060306030603061300B80001811030A000016710700167";
  153. attribute INIT_18 of ram_1024_x_18 : label is "002213000022A000800AA000C0F6B80080075D8BC011B800C0E9B80080B9A000";
  154. attribute INIT_19 of ram_1024_x_18 : label is "0F6301310F6901310F5001930193A00001310F20A00001310F0DA00001741200";
  155. attribute INIT_1A of ram_1024_x_18 : label is "01310F4E019601310F6501310F7A01310F6101310F6C01310F4201310F6F0131";
  156. attribute INIT_1B of ram_1024_x_18 : label is "019601310F4801310F5301310F4101310F4C01310F46019601310F5201310F4F";
  157. attribute INIT_1C of ram_1024_x_18 : label is "01310F6D01310F6D01310F6101310F7201310F6701310F6F01310F7201310F50";
  158. attribute INIT_1D of ram_1024_x_18 : label is "019301310F3001310F3001310F2E01310F3101310F76019601310F7201310F65";
  159. attribute INIT_1E of ram_1024_x_18 : label is "01310F6701310F6E01310F6901310F7401310F6901310F6101310F57A0000193";
  160. attribute INIT_1F of ram_1024_x_18 : label is "0F46019601310F5301310F4301310F4D019601310F7201310F6F01310F660196";
  161. attribute INIT_20 of ram_1024_x_18 : label is "0F50019601310F6E01310F690220A000019301310F6501310F6C01310F690131";
  162. attribute INIT_21 of ram_1024_x_18 : label is "A0000193013101310F7301310F6501310F7201310F6701310F6F01310F720131";
  163. attribute INIT_22 of ram_1024_x_18 : label is "0F4B01310F4F0193A000019601310F6501310F7301310F6101310F7201310F45";
  164. attribute INIT_23 of ram_1024_x_18 : label is "0F420193013101310F6C01310F61022001310F2D01310F450193A00001930131";
  165. attribute INIT_24 of ram_1024_x_18 : label is "01310F7301310F6B01310F6301310F6F01310F6C01310F62022001310F2D0131";
  166. attribute INIT_25 of ram_1024_x_18 : label is "01310F7201310F5001310F2D01310F50019301310F3301310F2D01310F310196";
  167. attribute INIT_26 of ram_1024_x_18 : label is "0F5701310F2D01310F5701F701310F6D01310F6101310F7201310F6701310F6F";
  168. attribute INIT_27 of ram_1024_x_18 : label is "01310F2D01310F52019302CB019601310F6501310F7401310F6901310F720131";
  169. attribute INIT_28 of ram_1024_x_18 : label is "019601310F3601310F3501310F32019601310F6401310F6101310F6501310F52";
  170. attribute INIT_29 of ram_1024_x_18 : label is "01310F6901310F7601310F6501310F4401310F2D01310F49019301310F7302CB";
  171. attribute INIT_2A of ram_1024_x_18 : label is "0F6C01310F6501310F4801310F2D01310F48019302C6019601310F6501310F63";
  172. attribute INIT_2B of ram_1024_x_18 : label is "01310F7401310F6101310F7401310F5301310F2D01310F53019301310F700131";
  173. attribute INIT_2C of ram_1024_x_18 : label is "0F7401310F7901310F62A00001310F4401310F49A000019301310F7301310F75";
  174. attribute INIT_2D of ram_1024_x_18 : label is "0F7201310F6901310F6601310F6E01310F6F01310F430193A00001310F650131";
  175. attribute INIT_2E of ram_1024_x_18 : label is "019601310F2901310F6E01310F2F01310F5901310F280220019601310F6D0131";
  176. attribute INIT_2F of ram_1024_x_18 : label is "0F610193A000019301310F7401310F7201310F6F01310F6201310F410193A000";
  177. attribute INIT_30 of ram_1024_x_18 : label is "0F640193A00001310F3D013101310F7301310F6501310F72013101310F640131";
  178. attribute INIT_31 of ram_1024_x_18 : label is "00000000000000000000000000000000430B01310F6101310F7401310F610131";
  179. attribute INIT_32 of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  180. attribute INIT_33 of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  181. attribute INIT_34 of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  182. attribute INIT_35 of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  183. attribute INIT_36 of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  184. attribute INIT_37 of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  185. attribute INIT_38 of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  186. attribute INIT_39 of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  187. attribute INIT_3A of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  188. attribute INIT_3B of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  189. attribute INIT_3C of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  190. attribute INIT_3D of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  191. attribute INIT_3E of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000000000000000";
  192. attribute INIT_3F of ram_1024_x_18 : label is "43F580016000C004001143FC001353FB20104000E00000000000000000000000";
  193. attribute INITP_00 of ram_1024_x_18 : label is "34DF2118674436CC99F73CFD9FFFEF33FF7C0FF7FCCA2CFFF3DDDDDDDDF3FFFF";
  194. attribute INITP_01 of ram_1024_x_18 : label is "BDD42CA08AAA022AFFFC03FF3FC03CFBDDD5F3F3FCF3CFEF33FFF3CF3FBCD55C";
  195. attribute INITP_02 of ram_1024_x_18 : label is "2CAA2CB332CCE5D8C0EA89B19A2C998999752BD3D3D2F4F4EDCB72DCB72D2F33";
  196. attribute INITP_03 of ram_1024_x_18 : label is "3CCCF333CCCCCCCBF33333CCCCCCCCCCF33333CCCF333333333ECB2CCE667666";
  197. attribute INITP_04 of ram_1024_x_18 : label is "CCFF3333333CCCCCCCCCF333CCCCCCF33F33CCEF33BCCCCCBF3333333CCEF333";
  198. attribute INITP_05 of ram_1024_x_18 : label is "3BCCCCCEF33333F3333333B3332CCBCCCCCCCCF333333FCCCCCCCCF3F333CCCC";
  199. attribute INITP_06 of ram_1024_x_18 : label is "0000000000000000000000000000000000000000000000000000F3333B3CCCF3";
  200. attribute INITP_07 of ram_1024_x_18 : label is "F233480000000000000000000000000000000000000000000000000000000000";
  201. --
  202. begin
  203. --
  204. --Instantiate the Xilinx primitive for a block RAM
  205. ram_1024_x_18: RAMB16_S9_S18
  206. --synthesis translate_off
  207. --INIT values repeated to define contents for functional simulation
  208. generic map (INIT_00 => X"502C4042502A4045002201310F3E019301930193023301990193C001011A0027",
  209. INIT_01 => X"013101310F3F019350D540535003404850C2404950A34052508C405750474050",
  210. INIT_02 => X"011F02D401930904402D09FEA000C0080006A000013E10F00131011F40070131",
  211. INIT_03 => X"02F14007022C5C38C902004101310F2E07000800019302090193543F4F590131",
  212. INIT_04 => X"B0004B01006700574007022C004C01E20193A00000F700EA01D000EA01204007",
  213. INIT_05 => X"B0004F0AB0004F0D011F54584F3A011F0E2B404C00776A2B0193016D504C4B04",
  214. INIT_06 => X"8D02B4004B0450724B007BD08D037CD00D2B405B8E01F0E0017412F0011F13F0",
  215. INIT_07 => X"032F00EAC10111A05077208000E000EA01E8A00078D0CD0177D0CD01A00079D0",
  216. INIT_08 => X"1900588C018D02FEA00000F700EA01D05480CA018301A900A800870100EA7130",
  217. INIT_09 => X"110000EA01404007022C0193009D5896018D030E1700588C018D1800588C018D",
  218. INIT_0A => X"022C00B10193170058A3018D180058A3018D190058A3018D02FEA00000F700EA",
  219. INIT_0B => X"54B2C60154B6C5010167A900A800870100E0019605100196016D019306104007",
  220. INIT_0C => X"07020196016700E000EA0190070008000900019601310F3D02C60193A0000193",
  221. INIT_0D => X"400700F40193016700E0019300EA0170070008000900400700F40193016700E0",
  222. INIT_0E => X"C1080100C110C720C840C980A000C108400201060106C1080105C720C840C980",
  223. INIT_0F => X"A00000F450F9208000E0AE008D010D000E00A00000EA01FFA000C10801060106",
  224. INIT_10 => X"A000550CC10101070128A0005508C001000BA0000193016710D0016710E00193",
  225. INIT_11 => X"C000A000551BC40101150414A0005516C30101100314A0005511C201010B0219",
  226. INIT_12 => X"51204F114F014129552D20084000A000C00151294F134F014120552420084000",
  227. INIT_13 => X"B8004061A000803AC1015D38C00A81010130A000CF0441315135200140004129",
  228. INIT_14 => X"02069200020602061200B80001447010A000C0F6B80080C6A000A0DFBC00407B",
  229. INIT_15 => X"0162A00F101012000162000E000E000E000E1100A0009200B800014470108101",
  230. INIT_16 => X"108001671090A00001311F1001311F200156A000803A80075965C00AA0001100",
  231. INIT_17 => X"D030B8000181102003060306030603061300B80001811030A000016710700167",
  232. INIT_18 => X"002213000022A000800AA000C0F6B80080075D8BC011B800C0E9B80080B9A000",
  233. INIT_19 => X"0F6301310F6901310F5001930193A00001310F20A00001310F0DA00001741200",
  234. INIT_1A => X"01310F4E019601310F6501310F7A01310F6101310F6C01310F4201310F6F0131",
  235. INIT_1B => X"019601310F4801310F5301310F4101310F4C01310F46019601310F5201310F4F",
  236. INIT_1C => X"01310F6D01310F6D01310F6101310F7201310F6701310F6F01310F7201310F50",
  237. INIT_1D => X"019301310F3001310F3001310F2E01310F3101310F76019601310F7201310F65",
  238. INIT_1E => X"01310F6701310F6E01310F6901310F7401310F6901310F6101310F57A0000193",
  239. INIT_1F => X"0F46019601310F5301310F4301310F4D019601310F7201310F6F01310F660196",
  240. INIT_20 => X"0F50019601310F6E01310F690220A000019301310F6501310F6C01310F690131",
  241. INIT_21 => X"A0000193013101310F7301310F6501310F7201310F6701310F6F01310F720131",
  242. INIT_22 => X"0F4B01310F4F0193A000019601310F6501310F7301310F6101310F7201310F45",
  243. INIT_23 => X"0F420193013101310F6C01310F61022001310F2D01310F450193A00001930131",
  244. INIT_24 => X"01310F7301310F6B01310F6301310F6F01310F6C01310F62022001310F2D0131",
  245. INIT_25 => X"01310F7201310F5001310F2D01310F50019301310F3301310F2D01310F310196",
  246. INIT_26 => X"0F5701310F2D01310F5701F701310F6D01310F6101310F7201310F6701310F6F",
  247. INIT_27 => X"01310F2D01310F52019302CB019601310F6501310F7401310F6901310F720131",
  248. INIT_28 => X"019601310F3601310F3501310F32019601310F6401310F6101310F6501310F52",
  249. INIT_29 => X"01310F6901310F7601310F6501310F4401310F2D01310F49019301310F7302CB",
  250. INIT_2A => X"0F6C01310F6501310F4801310F2D01310F48019302C6019601310F6501310F63",
  251. INIT_2B => X"01310F7401310F6101310F7401310F5301310F2D01310F53019301310F700131",
  252. INIT_2C => X"0F7401310F7901310F62A00001310F4401310F49A000019301310F7301310F75",
  253. INIT_2D => X"0F7201310F6901310F6601310F6E01310F6F01310F430193A00001310F650131",
  254. INIT_2E => X"019601310F2901310F6E01310F2F01310F5901310F280220019601310F6D0131",
  255. INIT_2F => X"0F610193A000019301310F7401310F7201310F6F01310F6201310F410193A000",
  256. INIT_30 => X"0F640193A00001310F3D013101310F7301310F6501310F72013101310F640131",
  257. INIT_31 => X"00000000000000000000000000000000430B01310F6101310F7401310F610131",
  258. INIT_32 => X"0000000000000000000000000000000000000000000000000000000000000000",
  259. INIT_33 => X"0000000000000000000000000000000000000000000000000000000000000000",
  260. INIT_34 => X"0000000000000000000000000000000000000000000000000000000000000000",
  261. INIT_35 => X"0000000000000000000000000000000000000000000000000000000000000000",
  262. INIT_36 => X"0000000000000000000000000000000000000000000000000000000000000000",
  263. INIT_37 => X"0000000000000000000000000000000000000000000000000000000000000000",
  264. INIT_38 => X"0000000000000000000000000000000000000000000000000000000000000000",
  265. INIT_39 => X"0000000000000000000000000000000000000000000000000000000000000000",
  266. INIT_3A => X"0000000000000000000000000000000000000000000000000000000000000000",
  267. INIT_3B => X"0000000000000000000000000000000000000000000000000000000000000000",
  268. INIT_3C => X"0000000000000000000000000000000000000000000000000000000000000000",
  269. INIT_3D => X"0000000000000000000000000000000000000000000000000000000000000000",
  270. INIT_3E => X"0000000000000000000000000000000000000000000000000000000000000000",
  271. INIT_3F => X"43F580016000C004001143FC001353FB20104000E00000000000000000000000",
  272. INITP_00 => X"34DF2118674436CC99F73CFD9FFFEF33FF7C0FF7FCCA2CFFF3DDDDDDDDF3FFFF",
  273. INITP_01 => X"BDD42CA08AAA022AFFFC03FF3FC03CFBDDD5F3F3FCF3CFEF33FFF3CF3FBCD55C",
  274. INITP_02 => X"2CAA2CB332CCE5D8C0EA89B19A2C998999752BD3D3D2F4F4EDCB72DCB72D2F33",
  275. INITP_03 => X"3CCCF333CCCCCCCBF33333CCCCCCCCCCF33333CCCF333333333ECB2CCE667666",
  276. INITP_04 => X"CCFF3333333CCCCCCCCCF333CCCCCCF33F33CCEF33BCCCCCBF3333333CCEF333",
  277. INITP_05 => X"3BCCCCCEF33333F3333333B3332CCBCCCCCCCCF333333FCCCCCCCCF3F333CCCC",
  278. INITP_06 => X"0000000000000000000000000000000000000000000000000000F3333B3CCCF3",
  279. INITP_07 => X"F233480000000000000000000000000000000000000000000000000000000000")
  280. --synthesis translate_on
  281. port map( DIB => "0000000000000000",
  282. DIPB => "00",
  283. ENB => '1',
  284. WEB => '0',
  285. SSRB => '0',
  286. CLKB => clk,
  287. ADDRB => address,
  288. DOB => instruction(15 downto 0),
  289. DOPB => instruction(17 downto 16),
  290. DIA => jdata,
  291. DIPA => jparity,
  292. ENA => sel1,
  293. WEA => '1',
  294. SSRA => '0',
  295. CLKA => update,
  296. ADDRA=> jaddr,
  297. DOA => doa(7 downto 0),
  298. DOPA => dopa);
  299. v2_bscan: BSCAN_VIRTEX2
  300. port map( TDO1 => tdo1,
  301. TDO2 => tdo2,
  302. UPDATE => update,
  303. SHIFT => shift,
  304. RESET => reset,
  305. TDI => tdi,
  306. SEL1 => sel1,
  307. DRCK1 => drck1,
  308. SEL2 => sel2,
  309. DRCK2 => drck2,
  310. CAPTURE => capture);
  311. --buffer signal used as a clock
  312. upload_clock: BUFG
  313. port map( I => drck1,
  314. O => drck1_buf);
  315. -- Assign the reset to be active whenever the uploading subsystem is active
  316. proc_reset <= sel1;
  317. srlC1: SRLC16E
  318. --synthesis translate_off
  319. generic map (INIT => X"0000")
  320. --synthesis translate_on
  321. port map( D => tdi,
  322. CE => '1',
  323. CLK => drck1_buf,
  324. A0 => '1',
  325. A1 => '0',
  326. A2 => '1',
  327. A3 => '1',
  328. Q => jaddr(10),
  329. Q15 => jaddr(8));
  330. flop1: FD
  331. port map ( D => jaddr(10),
  332. Q => jaddr(9),
  333. C => drck1_buf);
  334. srlC2: SRLC16E
  335. --synthesis translate_off
  336. generic map (INIT => X"0000")
  337. --synthesis translate_on
  338. port map( D => jaddr(8),
  339. CE => '1',
  340. CLK => drck1_buf,
  341. A0 => '1',
  342. A1 => '0',
  343. A2 => '1',
  344. A3 => '1',
  345. Q => jaddr(7),
  346. Q15 => tap5);
  347. flop2: FD
  348. port map ( D => jaddr(7),
  349. Q => jaddr(6),
  350. C => drck1_buf);
  351. srlC3: SRLC16E
  352. --synthesis translate_off
  353. generic map (INIT => X"0000")
  354. --synthesis translate_on
  355. port map( D => tap5,
  356. CE => '1',
  357. CLK => drck1_buf,
  358. A0 => '1',
  359. A1 => '0',
  360. A2 => '1',
  361. A3 => '1',
  362. Q => jaddr(5),
  363. Q15 => jaddr(3));
  364. flop3: FD
  365. port map ( D => jaddr(5),
  366. Q => jaddr(4),
  367. C => drck1_buf);
  368. srlC4: SRLC16E
  369. --synthesis translate_off
  370. generic map (INIT => X"0000")
  371. --synthesis translate_on
  372. port map( D => jaddr(3),
  373. CE => '1',
  374. CLK => drck1_buf,
  375. A0 => '1',
  376. A1 => '0',
  377. A2 => '1',
  378. A3 => '1',
  379. Q => jaddr(2),
  380. Q15 => tap11);
  381. flop4: FD
  382. port map ( D => jaddr(2),
  383. Q => jaddr(1),
  384. C => drck1_buf);
  385. srlC5: SRLC16E
  386. --synthesis translate_off
  387. generic map (INIT => X"0000")
  388. --synthesis translate_on
  389. port map( D => tap11,
  390. CE => '1',
  391. CLK => drck1_buf,
  392. A0 => '1',
  393. A1 => '0',
  394. A2 => '1',
  395. A3 => '1',
  396. Q => jaddr(0),
  397. Q15 => jdata(7));
  398. flop5: FD
  399. port map ( D => jaddr(0),
  400. Q => jparity(0),
  401. C => drck1_buf);
  402. srlC6: SRLC16E
  403. --synthesis translate_off
  404. generic map (INIT => X"0000")
  405. --synthesis translate_on
  406. port map( D => jdata(7),
  407. CE => '1',
  408. CLK => drck1_buf,
  409. A0 => '1',
  410. A1 => '0',
  411. A2 => '1',
  412. A3 => '1',
  413. Q => jdata(6),
  414. Q15 => tap17);
  415. flop6: FD
  416. port map ( D => jdata(6),
  417. Q => jdata(5),
  418. C => drck1_buf);
  419. srlC7: SRLC16E
  420. --synthesis translate_off
  421. generic map (INIT => X"0000")
  422. --synthesis translate_on
  423. port map( D => tap17,
  424. CE => '1',
  425. CLK => drck1_buf,
  426. A0 => '1',
  427. A1 => '0',
  428. A2 => '1',
  429. A3 => '1',
  430. Q => jdata(4),
  431. Q15 => jdata(2));
  432. flop7: FD
  433. port map ( D => jdata(4),
  434. Q => jdata(3),
  435. C => drck1_buf);
  436. srlC8: SRLC16E
  437. --synthesis translate_off
  438. generic map (INIT => X"0000")
  439. --synthesis translate_on
  440. port map( D => jdata(2),
  441. CE => '1',
  442. CLK => drck1_buf,
  443. A0 => '1',
  444. A1 => '0',
  445. A2 => '1',
  446. A3 => '1',
  447. Q => jdata(1),
  448. Q15 => tdo1);
  449. flop8: FD
  450. port map ( D => jdata(1),
  451. Q => jdata(0),
  452. C => drck1_buf);
  453. end low_level_definition;
  454. --
  455. ------------------------------------------------------------------------------------
  456. --
  457. -- END OF FILE progctrl.vhd
  458. --
  459. ------------------------------------------------------------------------------------