1875c7893SWolfgang Denk /* 2875c7893SWolfgang Denk * (C) Copyright 2002 3875c7893SWolfgang Denk * Rich Ireland, Enterasys Networks, rireland@enterasys.com. 4875c7893SWolfgang Denk * 5*1a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 6875c7893SWolfgang Denk */ 7875c7893SWolfgang Denk 8875c7893SWolfgang Denk #ifndef _SPARTAN3_H_ 9875c7893SWolfgang Denk #define _SPARTAN3_H_ 10875c7893SWolfgang Denk 11875c7893SWolfgang Denk #include <xilinx.h> 12875c7893SWolfgang Denk 13e6a857daSWolfgang Denk extern int Spartan3_load(Xilinx_desc *desc, const void *image, size_t size); 14e6a857daSWolfgang Denk extern int Spartan3_dump(Xilinx_desc *desc, const void *buf, size_t bsize); 15875c7893SWolfgang Denk extern int Spartan3_info(Xilinx_desc *desc); 16875c7893SWolfgang Denk 17875c7893SWolfgang Denk /* Slave Parallel Implementation function table */ 18875c7893SWolfgang Denk typedef struct { 19875c7893SWolfgang Denk Xilinx_pre_fn pre; 20875c7893SWolfgang Denk Xilinx_pgm_fn pgm; 21875c7893SWolfgang Denk Xilinx_init_fn init; 22875c7893SWolfgang Denk Xilinx_err_fn err; 23875c7893SWolfgang Denk Xilinx_done_fn done; 24875c7893SWolfgang Denk Xilinx_clk_fn clk; 25875c7893SWolfgang Denk Xilinx_cs_fn cs; 26875c7893SWolfgang Denk Xilinx_wr_fn wr; 27875c7893SWolfgang Denk Xilinx_rdata_fn rdata; 28875c7893SWolfgang Denk Xilinx_wdata_fn wdata; 29875c7893SWolfgang Denk Xilinx_busy_fn busy; 30875c7893SWolfgang Denk Xilinx_abort_fn abort; 31875c7893SWolfgang Denk Xilinx_post_fn post; 32875c7893SWolfgang Denk } Xilinx_Spartan3_Slave_Parallel_fns; 33875c7893SWolfgang Denk 34875c7893SWolfgang Denk /* Slave Serial Implementation function table */ 35875c7893SWolfgang Denk typedef struct { 36875c7893SWolfgang Denk Xilinx_pre_fn pre; 37875c7893SWolfgang Denk Xilinx_pgm_fn pgm; 38875c7893SWolfgang Denk Xilinx_clk_fn clk; 39875c7893SWolfgang Denk Xilinx_init_fn init; 40875c7893SWolfgang Denk Xilinx_done_fn done; 41875c7893SWolfgang Denk Xilinx_wr_fn wr; 4221d39d59SMatthias Fuchs Xilinx_post_fn post; 4389083346SWolfgang Wegner Xilinx_bwr_fn bwr; /* block write function */ 44b0bc8b70SWolfgang Wegner Xilinx_abort_fn abort; 45875c7893SWolfgang Denk } Xilinx_Spartan3_Slave_Serial_fns; 46875c7893SWolfgang Denk 47875c7893SWolfgang Denk /* Device Image Sizes 48875c7893SWolfgang Denk *********************************************************************/ 49875c7893SWolfgang Denk /* Spartan-III (1.2V) */ 50875c7893SWolfgang Denk #define XILINX_XC3S50_SIZE 439264/8 51875c7893SWolfgang Denk #define XILINX_XC3S200_SIZE 1047616/8 52875c7893SWolfgang Denk #define XILINX_XC3S400_SIZE 1699136/8 53875c7893SWolfgang Denk #define XILINX_XC3S1000_SIZE 3223488/8 54875c7893SWolfgang Denk #define XILINX_XC3S1500_SIZE 5214784/8 55875c7893SWolfgang Denk #define XILINX_XC3S2000_SIZE 7673024/8 56875c7893SWolfgang Denk #define XILINX_XC3S4000_SIZE 11316864/8 57875c7893SWolfgang Denk #define XILINX_XC3S5000_SIZE 13271936/8 58875c7893SWolfgang Denk 59923efd28SBruce Adler /* Spartan-3E (v3.4) */ 60923efd28SBruce Adler #define XILINX_XC3S100E_SIZE 581344/8 61923efd28SBruce Adler #define XILINX_XC3S250E_SIZE 1353728/8 62923efd28SBruce Adler #define XILINX_XC3S500E_SIZE 2270208/8 63923efd28SBruce Adler #define XILINX_XC3S1200E_SIZE 3841184/8 64923efd28SBruce Adler #define XILINX_XC3S1600E_SIZE 5969696/8 65923efd28SBruce Adler 6628cdc1c8SStefano Babic /* 6728cdc1c8SStefano Babic * Spartan-6 : the Spartan-6 family can be programmed 6828cdc1c8SStefano Babic * exactly as the Spartan-3 6928cdc1c8SStefano Babic */ 7028cdc1c8SStefano Babic #define XILINK_XC6SLX4_SIZE (3713568/8) 7128cdc1c8SStefano Babic 72875c7893SWolfgang Denk /* Descriptor Macros 73875c7893SWolfgang Denk *********************************************************************/ 743bff4ffaSMatthias Fuchs /* Spartan-III devices */ 75875c7893SWolfgang Denk #define XILINX_XC3S50_DESC(iface, fn_table, cookie) \ 76875c7893SWolfgang Denk { Xilinx_Spartan3, iface, XILINX_XC3S50_SIZE, fn_table, cookie } 77875c7893SWolfgang Denk 78875c7893SWolfgang Denk #define XILINX_XC3S200_DESC(iface, fn_table, cookie) \ 79875c7893SWolfgang Denk { Xilinx_Spartan3, iface, XILINX_XC3S200_SIZE, fn_table, cookie } 80875c7893SWolfgang Denk 81875c7893SWolfgang Denk #define XILINX_XC3S400_DESC(iface, fn_table, cookie) \ 82875c7893SWolfgang Denk { Xilinx_Spartan3, iface, XILINX_XC3S400_SIZE, fn_table, cookie } 83875c7893SWolfgang Denk 84875c7893SWolfgang Denk #define XILINX_XC3S1000_DESC(iface, fn_table, cookie) \ 85875c7893SWolfgang Denk { Xilinx_Spartan3, iface, XILINX_XC3S1000_SIZE, fn_table, cookie } 86875c7893SWolfgang Denk 87875c7893SWolfgang Denk #define XILINX_XC3S1500_DESC(iface, fn_table, cookie) \ 88875c7893SWolfgang Denk { Xilinx_Spartan3, iface, XILINX_XC3S1500_SIZE, fn_table, cookie } 89875c7893SWolfgang Denk 90875c7893SWolfgang Denk #define XILINX_XC3S2000_DESC(iface, fn_table, cookie) \ 91a07faf7bSLaurent Pinchart { Xilinx_Spartan3, iface, XILINX_XC3S2000_SIZE, fn_table, cookie } 92875c7893SWolfgang Denk 93875c7893SWolfgang Denk #define XILINX_XC3S4000_DESC(iface, fn_table, cookie) \ 94a07faf7bSLaurent Pinchart { Xilinx_Spartan3, iface, XILINX_XC3S4000_SIZE, fn_table, cookie } 95875c7893SWolfgang Denk 96875c7893SWolfgang Denk #define XILINX_XC3S5000_DESC(iface, fn_table, cookie) \ 97a07faf7bSLaurent Pinchart { Xilinx_Spartan3, iface, XILINX_XC3S5000_SIZE, fn_table, cookie } 98875c7893SWolfgang Denk 99923efd28SBruce Adler /* Spartan-3E devices */ 100923efd28SBruce Adler #define XILINX_XC3S100E_DESC(iface, fn_table, cookie) \ 101923efd28SBruce Adler { Xilinx_Spartan3, iface, XILINX_XC3S100E_SIZE, fn_table, cookie } 102923efd28SBruce Adler 103923efd28SBruce Adler #define XILINX_XC3S250E_DESC(iface, fn_table, cookie) \ 104923efd28SBruce Adler { Xilinx_Spartan3, iface, XILINX_XC3S250E_SIZE, fn_table, cookie } 105923efd28SBruce Adler 106923efd28SBruce Adler #define XILINX_XC3S500E_DESC(iface, fn_table, cookie) \ 107923efd28SBruce Adler { Xilinx_Spartan3, iface, XILINX_XC3S500E_SIZE, fn_table, cookie } 108923efd28SBruce Adler 109923efd28SBruce Adler #define XILINX_XC3S1200E_DESC(iface, fn_table, cookie) \ 110923efd28SBruce Adler { Xilinx_Spartan3, iface, XILINX_XC3S1200E_SIZE, fn_table, cookie } 111923efd28SBruce Adler 112923efd28SBruce Adler #define XILINX_XC3S1600E_DESC(iface, fn_table, cookie) \ 113923efd28SBruce Adler { Xilinx_Spartan3, iface, XILINX_XC3S1600E_SIZE, fn_table, cookie } 114923efd28SBruce Adler 11528cdc1c8SStefano Babic #define XILINX_XC6SLX4_DESC(iface, fn_table, cookie) \ 11628cdc1c8SStefano Babic { Xilinx_Spartan3, iface, XILINK_XC6SLX4_SIZE, fn_table, cookie } 11728cdc1c8SStefano Babic 118875c7893SWolfgang Denk #endif /* _SPARTAN3_H_ */ 119