| /* | 
 |  * (C) Copyright 2002 | 
 |  * Rich Ireland, Enterasys Networks, rireland@enterasys.com. | 
 |  * | 
 |  * See file CREDITS for list of people who contributed to this | 
 |  * project. | 
 |  * | 
 |  * This program is free software; you can redistribute it and/or | 
 |  * modify it under the terms of the GNU General Public License as | 
 |  * published by the Free Software Foundation; either version 2 of | 
 |  * the License, or (at your option) any later version. | 
 |  * | 
 |  * This program is distributed in the hope that it will be useful, | 
 |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
 |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
 |  * GNU General Public License for more details. | 
 |  * | 
 |  * You should have received a copy of the GNU General Public License | 
 |  * along with this program; if not, write to the Free Software | 
 |  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, | 
 |  * MA 02111-1307 USA | 
 |  * | 
 |  */ | 
 |  | 
 | #ifndef _SPARTAN2_H_ | 
 | #define _SPARTAN2_H_ | 
 |  | 
 | #include <xilinx.h> | 
 |  | 
 | extern int Spartan2_load( Xilinx_desc *desc, void *image, size_t size ); | 
 | extern int Spartan2_dump( Xilinx_desc *desc, void *buf, size_t bsize ); | 
 | extern int Spartan2_info( Xilinx_desc *desc ); | 
 | extern int Spartan2_reloc( Xilinx_desc *desc, ulong reloc_off ); | 
 |  | 
 | /* Slave Parallel Implementation function table */ | 
 | typedef struct { | 
 | 	Xilinx_pre_fn	pre; | 
 | 	Xilinx_pgm_fn	pgm; | 
 | 	Xilinx_init_fn	init; | 
 | 	Xilinx_err_fn	err; | 
 | 	Xilinx_done_fn	done; | 
 | 	Xilinx_clk_fn	clk; | 
 | 	Xilinx_cs_fn	cs; | 
 | 	Xilinx_wr_fn	wr; | 
 | 	Xilinx_rdata_fn	rdata; | 
 | 	Xilinx_wdata_fn	wdata; | 
 | 	Xilinx_busy_fn	busy; | 
 | 	Xilinx_abort_fn	abort; | 
 | 	Xilinx_post_fn	post; | 
 | 	int           	relocated; | 
 | } Xilinx_Spartan2_Slave_Parallel_fns; | 
 |  | 
 | /* Slave Serial Implementation function table */ | 
 | typedef struct { | 
 | 	Xilinx_pre_fn	pre; | 
 | 	Xilinx_pgm_fn	pgm; | 
 | 	Xilinx_clk_fn	clk; | 
 | 	Xilinx_init_fn	init; | 
 | 	Xilinx_done_fn	done; | 
 | 	Xilinx_wr_fn	wr; | 
 | 	int           	relocated; | 
 | } Xilinx_Spartan2_Slave_Serial_fns; | 
 |  | 
 | /* Device Image Sizes | 
 |  *********************************************************************/ | 
 | /* Spartan-II (2.5V) */ | 
 | #define XILINX_XC2S15_SIZE  	197728/8 | 
 | #define XILINX_XC2S30_SIZE  	336800/8 | 
 | #define XILINX_XC2S50_SIZE  	559232/8 | 
 | #define XILINX_XC2S100_SIZE 	781248/8 | 
 | #define XILINX_XC2S150_SIZE 	1040128/8 | 
 |  | 
 | /* Spartan-IIE (1.8V) */ | 
 | #define XILINX_XC2S50E_SIZE     630048/8 | 
 | #define XILINX_XC2S100E_SIZE    863840/8 | 
 | #define XILINX_XC2S150E_SIZE    1134496/8 | 
 | #define XILINX_XC2S200E_SIZE    1442016/8 | 
 | #define XILINX_XC2S300E_SIZE    1875648/8 | 
 |  | 
 | /* Descriptor Macros | 
 |  *********************************************************************/ | 
 | /* Spartan-II devices */ | 
 | #define XILINX_XC2S15_DESC(iface, fn_table, cookie) \ | 
 | { Xilinx_Spartan2, iface, XILINX_XC2S15_SIZE, fn_table, cookie } | 
 |  | 
 | #define XILINX_XC2S30_DESC(iface, fn_table, cookie) \ | 
 | { Xilinx_Spartan2, iface, XILINX_XC2S30_SIZE, fn_table, cookie } | 
 |  | 
 | #define XILINX_XC2S50_DESC(iface, fn_table, cookie) \ | 
 | { Xilinx_Spartan2, iface, XILINX_XC2S50_SIZE, fn_table, cookie } | 
 |  | 
 | #define XILINX_XC2S100_DESC(iface, fn_table, cookie) \ | 
 | { Xilinx_Spartan2, iface, XILINX_XC2S100_SIZE, fn_table, cookie } | 
 |  | 
 | #define XILINX_XC2S150_DESC(iface, fn_table, cookie) \ | 
 | { Xilinx_Spartan2, iface, XILINX_XC2S150_SIZE, fn_table, cookie } | 
 |  | 
 | #define XILINX_XC2S50E_DESC(iface, fn_table, cookie) \ | 
 | { Xilinx_Spartan2, iface, XILINX_XC2S50E_SIZE, fn_table, cookie } | 
 |  | 
 | #define XILINX_XC2S100E_DESC(iface, fn_table, cookie) \ | 
 | { Xilinx_Spartan2, iface, XILINX_XC2S100E_SIZE, fn_table, cookie } | 
 |  | 
 | #define XILINX_XC2S150E_DESC(iface, fn_table, cookie) \ | 
 | { Xilinx_Spartan2, iface, XILINX_XC2S150E_SIZE, fn_table, cookie } | 
 |  | 
 | #define XILINX_XC2S200E_DESC(iface, fn_table, cookie) \ | 
 | { Xilinx_Spartan2, iface, XILINX_XC2S200E_SIZE, fn_table, cookie } | 
 |  | 
 | #define XILINX_XC2S300E_DESC(iface, fn_table, cookie) \ | 
 | { Xilinx_Spartan2, iface, XILINX_XC2S300E_SIZE, fn_table, cookie } | 
 |  | 
 | #endif /* _SPARTAN2_H_ */ |