You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					141 lines
				
				5.4 KiB
			
		
		
			
		
	
	
					141 lines
				
				5.4 KiB
			|   
											8 years ago
										 | /*
 | ||
|  |              LUFA Library | ||
|  |      Copyright (C) Dean Camera, 2017. | ||
|  | 
 | ||
|  |   dean [at] fourwalledcubicle [dot] com | ||
|  |            www.lufa-lib.org | ||
|  | */ | ||
|  | 
 | ||
|  | /*
 | ||
|  |   Copyright 2017  Dean Camera (dean [at] fourwalledcubicle [dot] com) | ||
|  | 
 | ||
|  |   Permission to use, copy, modify, distribute, and sell this | ||
|  |   software and its documentation for any purpose is hereby granted | ||
|  |   without fee, provided that the above copyright notice appear in | ||
|  |   all copies and that both that the copyright notice and this | ||
|  |   permission notice and warranty disclaimer appear in supporting | ||
|  |   documentation, and that the name of the author not be used in | ||
|  |   advertising or publicity pertaining to distribution of the | ||
|  |   software without specific, written prior permission. | ||
|  | 
 | ||
|  |   The author disclaims all warranties with regard to this | ||
|  |   software, including all implied warranties of merchantability | ||
|  |   and fitness.  In no event shall the author be liable for any | ||
|  |   special, indirect or consequential damages or any damages | ||
|  |   whatsoever resulting from loss of use, data or profits, whether | ||
|  |   in an action of contract, negligence or other tortious action, | ||
|  |   arising out of or in connection with the use or performance of | ||
|  |   this software. | ||
|  | */ | ||
|  | 
 | ||
|  | /** \file
 | ||
|  |  * | ||
|  |  *  Header file for XMEGANVM.c. | ||
|  |  */ | ||
|  | 
 | ||
|  | #ifndef _XMEGA_NVM_
 | ||
|  | #define _XMEGA_NVM_
 | ||
|  | 
 | ||
|  | 	/* Includes: */ | ||
|  | 		#include <avr/io.h>
 | ||
|  | 		#include <avr/interrupt.h>
 | ||
|  | 		#include <stdbool.h>
 | ||
|  | 
 | ||
|  | 		#include <LUFA/Common/Common.h>
 | ||
|  | 
 | ||
|  | 		#include "XPROGProtocol.h"
 | ||
|  | 		#include "XPROGTarget.h"
 | ||
|  | 		#include "Config/AppConfig.h"
 | ||
|  | 
 | ||
|  | 	/* Preprocessor Checks: */ | ||
|  | 		#if ((BOARD == BOARD_XPLAIN) || (BOARD == BOARD_XPLAIN_REV1))
 | ||
|  | 			#undef ENABLE_ISP_PROTOCOL
 | ||
|  | 
 | ||
|  | 			#if !defined(ENABLE_XPROG_PROTOCOL)
 | ||
|  | 				#define ENABLE_XPROG_PROTOCOL
 | ||
|  | 			#endif
 | ||
|  | 		#endif
 | ||
|  | 
 | ||
|  | 	/* Defines: */ | ||
|  | 		#define XMEGA_CRC_LENGTH_BYTES               3
 | ||
|  | 
 | ||
|  | 		#define XMEGA_NVM_REG_ADDR0                  0x00
 | ||
|  | 		#define XMEGA_NVM_REG_ADDR1                  0x01
 | ||
|  | 		#define XMEGA_NVM_REG_ADDR2                  0x02
 | ||
|  | 		#define XMEGA_NVM_REG_DAT0                   0x04
 | ||
|  | 		#define XMEGA_NVM_REG_DAT1                   0x05
 | ||
|  | 		#define XMEGA_NVM_REG_DAT2                   0x06
 | ||
|  | 		#define XMEGA_NVM_REG_CMD                    0x0A
 | ||
|  | 		#define XMEGA_NVM_REG_CTRLA                  0x0B
 | ||
|  | 		#define XMEGA_NVM_REG_CTRLB                  0x0C
 | ||
|  | 		#define XMEGA_NVM_REG_INTCTRL                0x0D
 | ||
|  | 		#define XMEGA_NVM_REG_STATUS                 0x0F
 | ||
|  | 		#define XMEGA_NVM_REG_LOCKBITS               0x10
 | ||
|  | 
 | ||
|  | 		#define XMEGA_NVM_BIT_CTRLA_CMDEX            (1 << 0)
 | ||
|  | 
 | ||
|  | 		#define XMEGA_NVM_CMD_NOOP                   0x00
 | ||
|  | 		#define XMEGA_NVM_CMD_CHIPERASE              0x40
 | ||
|  | 		#define XMEGA_NVM_CMD_READNVM                0x43
 | ||
|  | 		#define XMEGA_NVM_CMD_LOADFLASHPAGEBUFF      0x23
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEFLASHPAGEBUFF     0x26
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEFLASHPAGE         0x2B
 | ||
|  | 		#define XMEGA_NVM_CMD_WRITEFLASHPAGE         0x2E
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEWRITEFLASH        0x2F
 | ||
|  | 		#define XMEGA_NVM_CMD_FLASHCRC               0x78
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEAPPSEC            0x20
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEAPPSECPAGE        0x22
 | ||
|  | 		#define XMEGA_NVM_CMD_WRITEAPPSECPAGE        0x24
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEWRITEAPPSECPAGE   0x25
 | ||
|  | 		#define XMEGA_NVM_CMD_APPCRC                 0x38
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEBOOTSEC           0x68
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEBOOTSECPAGE       0x2A
 | ||
|  | 		#define XMEGA_NVM_CMD_WRITEBOOTSECPAGE       0x2C
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEWRITEBOOTSECPAGE  0x2D
 | ||
|  | 		#define XMEGA_NVM_CMD_BOOTCRC                0x39
 | ||
|  | 		#define XMEGA_NVM_CMD_READUSERSIG            0x03
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEUSERSIG           0x18
 | ||
|  | 		#define XMEGA_NVM_CMD_WRITEUSERSIG           0x1A
 | ||
|  | 		#define XMEGA_NVM_CMD_READCALIBRATION        0x02
 | ||
|  | 		#define XMEGA_NVM_CMD_READFUSE               0x07
 | ||
|  | 		#define XMEGA_NVM_CMD_WRITEFUSE              0x4C
 | ||
|  | 		#define XMEGA_NVM_CMD_WRITELOCK              0x08
 | ||
|  | 		#define XMEGA_NVM_CMD_LOADEEPROMPAGEBUFF     0x33
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEEEPROMPAGEBUFF    0x36
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEEEPROM            0x30
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEEEPROMPAGE        0x32
 | ||
|  | 		#define XMEGA_NVM_CMD_WRITEEEPROMPAGE        0x34
 | ||
|  | 		#define XMEGA_NVM_CMD_ERASEWRITEEEPROMPAGE   0x35
 | ||
|  | 		#define XMEGA_NVM_CMD_READEEPROM             0x06
 | ||
|  | 
 | ||
|  | 	/* Function Prototypes: */ | ||
|  | 		bool XMEGANVM_WaitWhileNVMBusBusy(void); | ||
|  | 		bool XMEGANVM_WaitWhileNVMControllerBusy(void); | ||
|  | 		bool XMEGANVM_EnablePDI(void); | ||
|  | 		void XMEGANVM_DisablePDI(void); | ||
|  | 		bool XMEGANVM_GetMemoryCRC(const uint8_t CRCCommand, | ||
|  | 			                       uint32_t* const CRCDest); | ||
|  | 		bool XMEGANVM_ReadMemory(const uint32_t ReadAddress, | ||
|  | 		                         uint8_t* ReadBuffer, | ||
|  | 		                         uint16_t ReadSize); | ||
|  | 		bool XMEGANVM_WriteByteMemory(const uint8_t WriteCommand, | ||
|  | 		                              const uint32_t WriteAddress, | ||
|  | 		                              const uint8_t Byte); | ||
|  | 		bool XMEGANVM_WritePageMemory(const uint8_t WriteBuffCommand, | ||
|  | 		                              const uint8_t EraseBuffCommand, | ||
|  | 		                              const uint8_t WritePageCommand, | ||
|  | 		                              const uint8_t PageMode, | ||
|  | 		                              const uint32_t WriteAddress, | ||
|  | 		                              const uint8_t* WriteBuffer, | ||
|  | 		                              uint16_t WriteSize); | ||
|  | 		bool XMEGANVM_EraseMemory(const uint8_t EraseCommand, | ||
|  | 		                          const uint32_t Address); | ||
|  | 
 | ||
|  | 		#if defined(INCLUDE_FROM_XMEGANVM_C)
 | ||
|  | 			static void XMEGANVM_SendNVMRegAddress(const uint8_t Register); | ||
|  | 			static void XMEGANVM_SendAddress(const uint32_t AbsoluteAddress); | ||
|  | 		#endif
 | ||
|  | 
 | ||
|  | #endif
 | ||
|  | 
 |