/*!
|
/*!
|
flashdemo -- demo for Flash memory access from firmware and host software for ZTEX USB-FPGA Module 1.15
|
Default firmware and loader for ZTEX USB-FPGA Modules 2.16
|
Copyright (C) 2009-2011 ZTEX GmbH.
|
Copyright (C) 2009-2014 ZTEX GmbH.
|
http://www.ztex.de
|
http://www.ztex.de
|
|
|
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
it under the terms of the GNU General Public License version 3 as
|
it under the terms of the GNU General Public License version 3 as
|
published by the Free Software Foundation.
|
published by the Free Software Foundation.
|
|
|
This program is distributed in the hope that it will be useful, but
|
This program is distributed in the hope that it will be useful, but
|
WITHOUT ANY WARRANTY; without even the implied warranty of
|
WITHOUT ANY WARRANTY; without even the implied warranty of
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
General Public License for more details.
|
General Public License for more details.
|
|
|
You should have received a copy of the GNU General Public License
|
You should have received a copy of the GNU General Public License
|
along with this program; if not, see http://www.gnu.org/licenses/.
|
along with this program; if not, see http://www.gnu.org/licenses/.
|
!*/
|
!*/
|
|
|
#include[ztex-conf.h] // Loads the configuration macros, see ztex-conf.h for the available macros
|
#include[ztex-conf.h] // Loads the configuration macros, see ztex-conf.h for the available macros
|
#include[ztex-utils.h] // include basic functions and variables
|
#include[ztex-utils.h] // include basic functions and variables
|
|
|
// select ZTEX USB FPGA Module 2.16 as target (required for FPGA configuration)
|
// select ZTEX USB FPGA Module 2.16 as target (required for FPGA configuration)
|
IDENTITY_UFM_2_16(10.16.0.0,0);
|
IDENTITY_UFM_2_16(10.16.0.0,0);
|
|
|
// enables high speed FPGA configuration via EP4
|
// enables high speed FPGA configuration via EP4
|
EP_CONFIG(2,0,BULK,OUT,512,4);
|
EP_CONFIG(2,0,BULK,OUT,512,4);
|
ENABLE_HS_FPGA_CONF(2);
|
ENABLE_HS_FPGA_CONF(2);
|
|
|
// enable Flash support
|
// enable Flash support
|
ENABLE_FLASH;
|
ENABLE_FLASH;
|
ENABLE_FLASH_BITSTREAM;
|
ENABLE_FLASH_BITSTREAM;
|
|
|
// this product string is also used for identification by the host software
|
// this product string is also used for identification by the host software
|
#define[PRODUCT_STRING]["USB-FPGA Module 2.16 (default)"]
|
#define[PRODUCT_STRING]["USB-FPGA Module 2.16 (default)"]
|
|
|
// include the main part of the firmware kit, define the descriptors, ...
|
// include the main part of the firmware kit, define the descriptors, ...
|
#include[ztex.h]
|
#include[ztex.h]
|
|
|
void main(void)
|
void main(void)
|
{
|
{
|
init_USB();
|
init_USB();
|
|
|
if ( config_data_valid ) {
|
if ( config_data_valid ) {
|
mac_eeprom_read ( (__xdata BYTE*) (productString+20), 6, 1 );
|
mac_eeprom_read ( (__xdata BYTE*) (productString+20), 6, 1 );
|
}
|
}
|
|
|
while (1) { } // twiddle thumbs
|
while (1) { } // twiddle thumbs
|
}
|
}
|
|
|
|
|