vendor.xilinx_spartan_3_6: Add Spartan3A family support.
This commit is contained in:
		
							parent
							
								
									cb02a452e9
								
							
						
					
					
						commit
						b404d603fb
					
				|  | @ -6,10 +6,14 @@ from ..hdl.ir import * | ||||||
| from ..build import * | from ..build import * | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| __all__ = ["XilinxSpartan6Platform"] | __all__ = ["XilinxSpartan3APlatform", "XilinxSpartan6Platform"] | ||||||
|  | 
 | ||||||
|  | # The interface to Spartan 3 and 6 are substantially the same. Handle | ||||||
|  | # differences internally using one class and expose user-aliases for | ||||||
|  | # convenience. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class XilinxSpartan6Platform(TemplatedPlatform): | class XilinxSpartan3Or6Platform(TemplatedPlatform): | ||||||
|     """ |     """ | ||||||
|     Required tools: |     Required tools: | ||||||
|         * ISE toolchain: |         * ISE toolchain: | ||||||
|  | @ -45,7 +49,8 @@ class XilinxSpartan6Platform(TemplatedPlatform): | ||||||
|         * ``{{name}}_par.ncd``: place and routed netlist. |         * ``{{name}}_par.ncd``: place and routed netlist. | ||||||
|         * ``{{name}}.drc``: DRC report. |         * ``{{name}}.drc``: DRC report. | ||||||
|         * ``{{name}}.bgn``: BitGen log. |         * ``{{name}}.bgn``: BitGen log. | ||||||
|         * ``{{name}}.bit``: binary bitstream. |         * ``{{name}}.bit``: binary bitstream with metadata. | ||||||
|  |         * ``{{name}}.bin``: raw binary bitstream. | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     toolchain = "ISE" |     toolchain = "ISE" | ||||||
|  | @ -76,6 +81,10 @@ class XilinxSpartan6Platform(TemplatedPlatform): | ||||||
|             -ifn {{name}}.prj |             -ifn {{name}}.prj | ||||||
|             -ofn {{name}}.ngc |             -ofn {{name}}.ngc | ||||||
|             -top {{name}} |             -top {{name}} | ||||||
|  |             {% if platform.family in ["3", "3E", "3A"] %} | ||||||
|  |             -use_new_parser yes | ||||||
|  |             {% endif %} | ||||||
|  |             -register_balancing yes | ||||||
|             -p {{platform.device}}{{platform.package}}-{{platform.speed}} |             -p {{platform.device}}{{platform.package}}-{{platform.speed}} | ||||||
|             {{get_override("script_after_run")|default("# (script_after_run placeholder)")}} |             {{get_override("script_after_run")|default("# (script_after_run placeholder)")}} | ||||||
|         """, |         """, | ||||||
|  | @ -127,11 +136,29 @@ class XilinxSpartan6Platform(TemplatedPlatform): | ||||||
|         r""" |         r""" | ||||||
|         {{get_tool("bitgen")}} |         {{get_tool("bitgen")}} | ||||||
|             {{get_override("bitgen_opts")|default(["-w"])|options}} |             {{get_override("bitgen_opts")|default(["-w"])|options}} | ||||||
|  |             -g Binary:Yes | ||||||
|             {{name}}_par.ncd |             {{name}}_par.ncd | ||||||
|             {{name}}.bit |             {{name}}.bit | ||||||
|         """ |         """ | ||||||
|     ] |     ] | ||||||
| 
 | 
 | ||||||
|  |     @property | ||||||
|  |     def family(self): | ||||||
|  |         device = self.device.upper() | ||||||
|  |         if device.startswith("XC3S"): | ||||||
|  |             if device.endswith("A"): | ||||||
|  |                 return "3A" | ||||||
|  |             elif device.endswith("E"): | ||||||
|  |                 raise NotImplementedError("""Spartan 3E family is not supported | ||||||
|  |                                            as a nMigen platform.""") | ||||||
|  |             else: | ||||||
|  |                 raise NotImplementedError("""Spartan 3 family is not supported | ||||||
|  |                                            as a nMigen platform.""") | ||||||
|  |         elif device.startswith("XC6S"): | ||||||
|  |             return "6" | ||||||
|  |         else: | ||||||
|  |             assert False | ||||||
|  | 
 | ||||||
|     def _get_xdr_buffer(self, m, pin, i_invert=None, o_invert=None): |     def _get_xdr_buffer(self, m, pin, i_invert=None, o_invert=None): | ||||||
|         def get_dff(clk, d, q): |         def get_dff(clk, d, q): | ||||||
|             # SDR I/O is performed by packing a flip-flop into the pad IOB. |             # SDR I/O is performed by packing a flip-flop into the pad IOB. | ||||||
|  | @ -353,3 +380,7 @@ class XilinxSpartan6Platform(TemplatedPlatform): | ||||||
|                 io_IO=p_port[bit], io_IOB=n_port[bit] |                 io_IO=p_port[bit], io_IOB=n_port[bit] | ||||||
|             ) |             ) | ||||||
|         return m |         return m | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | XilinxSpartan3APlatform = XilinxSpartan3Or6Platform | ||||||
|  | XilinxSpartan6Platform = XilinxSpartan3Or6Platform | ||||||
		Loading…
	
		Reference in a new issue
	
	 William D. Jones
						William D. Jones