|  | /* | 
|  | * (C) Copyright 2003 | 
|  | * Steven Scholz, imc Measurement & Control, steven.scholz@imc-berlin.de | 
|  | * | 
|  | * (C) Copyright 2002 | 
|  | * Rich Ireland, Enterasys Networks, rireland@enterasys.com. | 
|  | * | 
|  | * SPDX-License-Identifier:	GPL-2.0+ | 
|  | */ | 
|  |  | 
|  | #ifndef _ACEX1K_H_ | 
|  | #define _ACEX1K_H_ | 
|  |  | 
|  | #include <altera.h> | 
|  |  | 
|  | extern int ACEX1K_load(Altera_desc *desc, const void *image, size_t size); | 
|  | extern int ACEX1K_dump(Altera_desc *desc, const void *buf, size_t bsize); | 
|  | extern int ACEX1K_info(Altera_desc *desc); | 
|  |  | 
|  | extern int CYC2_load(Altera_desc *desc, const void *image, size_t size); | 
|  | extern int CYC2_dump(Altera_desc *desc, const void *buf, size_t bsize); | 
|  | extern int CYC2_info(Altera_desc *desc); | 
|  |  | 
|  | /* Slave Serial Implementation function table */ | 
|  | typedef struct { | 
|  | Altera_pre_fn		pre; | 
|  | Altera_config_fn	config; | 
|  | Altera_clk_fn		clk; | 
|  | Altera_status_fn	status; | 
|  | Altera_done_fn		done; | 
|  | Altera_data_fn		data; | 
|  | Altera_abort_fn		abort; | 
|  | Altera_post_fn		post; | 
|  | } Altera_ACEX1K_Passive_Serial_fns; | 
|  |  | 
|  | /* Slave Serial Implementation function table */ | 
|  | typedef struct { | 
|  | Altera_pre_fn		pre; | 
|  | Altera_config_fn	config; | 
|  | Altera_status_fn	status; | 
|  | Altera_done_fn		done; | 
|  | Altera_write_fn		write; | 
|  | Altera_abort_fn		abort; | 
|  | Altera_post_fn		post; | 
|  | } Altera_CYC2_Passive_Serial_fns; | 
|  |  | 
|  | /* Device Image Sizes | 
|  | *********************************************************************/ | 
|  | /* ACEX1K */ | 
|  | /* FIXME: Which size do we mean? | 
|  | * Datasheet says 1337000/8=167125Bytes, | 
|  | * Filesize of an *.rbf file is 166965 Bytes | 
|  | */ | 
|  | #if 0 | 
|  | #define Altera_EP1K100_SIZE	1337000/8	/* 167125 Bytes */ | 
|  | #endif | 
|  | #define Altera_EP1K100_SIZE	(166965*8) | 
|  |  | 
|  | #define Altera_EP2C8_SIZE	247942 | 
|  | #define Altera_EP2C20_SIZE	586562 | 
|  | #define Altera_EP2C35_SIZE	883905 | 
|  | #define Altera_EP3C5_SIZE	368011		/* .rbf size in bytes */ | 
|  |  | 
|  | /* Descriptor Macros | 
|  | *********************************************************************/ | 
|  | /* ACEX1K devices */ | 
|  | #define Altera_EP1K100_DESC(iface, fn_table, cookie) \ | 
|  | { Altera_ACEX1K, iface, Altera_EP1K100_SIZE, fn_table, cookie } | 
|  |  | 
|  | #endif /* _ACEX1K_H_ */ |