122 lines
5.6 KiB
C
122 lines
5.6 KiB
C
/***********************************************************************************************************************
|
|
* DISCLAIMER
|
|
* This software is supplied by Renesas Electronics Corporation and is only intended for use with Renesas products.
|
|
* No other uses are authorized. This software is owned by Renesas Electronics Corporation and is protected under all
|
|
* applicable laws, including copyright laws.
|
|
* THIS SOFTWARE IS PROVIDED "AS IS" AND RENESAS MAKES NO WARRANTIESREGARDING THIS SOFTWARE, WHETHER EXPRESS, IMPLIED
|
|
* OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
* NON-INFRINGEMENT. ALL SUCH WARRANTIES ARE EXPRESSLY DISCLAIMED.TO THE MAXIMUM EXTENT PERMITTED NOT PROHIBITED BY
|
|
* LAW, NEITHER RENESAS ELECTRONICS CORPORATION NOR ANY OF ITS AFFILIATED COMPANIES SHALL BE LIABLE FOR ANY DIRECT,
|
|
* INDIRECT, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES FOR ANY REASON RELATED TO THIS SOFTWARE, EVEN IF RENESAS OR
|
|
* ITS AFFILIATES HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
|
|
* Renesas reserves the right, without notice, to make changes to this software and to discontinue the availability
|
|
* of this software. By using this software, you agree to the additional terms and conditions found by accessing the
|
|
* following link:
|
|
* http://www.renesas.com/disclaimer
|
|
*
|
|
* Copyright (C) 2012, 2015 Renesas Electronics Corporation. All rights reserved.
|
|
***********************************************************************************************************************/
|
|
|
|
/***********************************************************************************************************************
|
|
* File Name : boot_macrodriver.h
|
|
* Version : CodeGenerator for RL78/F13 V2.02.01.03 [30 Jan 2015]
|
|
* Device(s) : R5F10BLG
|
|
* Tool-Chain : CA78K0R
|
|
* Description : This file implements general head file.
|
|
* Creation Date: 2017/7/4
|
|
***********************************************************************************************************************/
|
|
|
|
#ifndef STATUS_H
|
|
#define STATUS_H
|
|
/***********************************************************************************************************************
|
|
Includes
|
|
***********************************************************************************************************************/
|
|
#pragma sfr
|
|
#pragma DI
|
|
#pragma EI
|
|
#pragma NOP
|
|
#pragma HALT
|
|
#pragma STOP
|
|
|
|
/***********************************************************************************************************************
|
|
Macro definitions (Register bit)
|
|
***********************************************************************************************************************/
|
|
|
|
/***********************************************************************************************************************
|
|
Macro definitions
|
|
***********************************************************************************************************************/
|
|
#ifndef __TYPEDEF__
|
|
/* Status list definition */
|
|
#define MD_STATUSBASE 0x00U
|
|
#define MD_OK (MD_STATUSBASE + 0x00U) /* register setting OK */
|
|
#define MD_SPT (MD_STATUSBASE + 0x01U) /* IIC stop */
|
|
#define MD_NACK (MD_STATUSBASE + 0x02U) /* IIC no ACK */
|
|
#define MD_BUSY1 (MD_STATUSBASE + 0x03U) /* busy 1 */
|
|
#define MD_BUSY2 (MD_STATUSBASE + 0x04U) /* busy 2 */
|
|
#define MD_OVERRUN (MD_STATUSBASE + 0x05U) /* IIC OVERRUN occur */
|
|
|
|
/* Error list definition */
|
|
#define MD_ERRORBASE 0x80U
|
|
#define MD_ERROR (MD_ERRORBASE + 0x00U) /* error */
|
|
#define MD_ARGERROR (MD_ERRORBASE + 0x01U) /* error agrument input error */
|
|
#define MD_ERROR1 (MD_ERRORBASE + 0x02U) /* error 1 */
|
|
#define MD_ERROR2 (MD_ERRORBASE + 0x03U) /* error 2 */
|
|
#define MD_ERROR3 (MD_ERRORBASE + 0x04U) /* error 3 */
|
|
#define MD_ERROR4 (MD_ERRORBASE + 0x05U) /* error 4 */
|
|
#define MD_DATAEXISTS (MD_ERRORBASE + 0x06U) /* data to be transferred next exists in TXBn register */
|
|
#endif
|
|
|
|
/***********************************************************************************************************************
|
|
Typedef definitions
|
|
***********************************************************************************************************************/
|
|
#ifndef __TYPEDEF__
|
|
typedef signed char int8_t;
|
|
typedef unsigned char uint8_t;
|
|
typedef signed short int16_t;
|
|
typedef unsigned short uint16_t;
|
|
typedef signed long int32_t;
|
|
typedef unsigned long uint32_t;
|
|
typedef unsigned short MD_STATUS;
|
|
#define __TYPEDEF__
|
|
#endif
|
|
//typedef signed char int8;
|
|
//typedef unsigned char uint8;
|
|
//typedef signed short int16;
|
|
//typedef unsigned short uint16;
|
|
//typedef signed long int32;
|
|
//typedef unsigned long uint32;
|
|
typedef struct{
|
|
uint8_t RspData[8];
|
|
uint8_t AckReq;
|
|
uint8_t AckLenth;
|
|
uint8_t boot_enable;
|
|
uint8_t RunAir;
|
|
uint8_t RstSrc;
|
|
uint8_t KeyErrTimes;
|
|
uint8_t SeedReqTimes;
|
|
}KamData_t;
|
|
|
|
#define WDT_RST 0x10
|
|
#define RPRGRM_REQ_VALID 0xA5
|
|
#define RUN_IN_BOOT 0x00
|
|
#define RUN_IN_APP 0xA5
|
|
#define ACK_REQ 0xA5
|
|
|
|
#define GetAppValid() (*(__far uint32 *)0xA100)
|
|
#define GetAppEndValid() (*(__far uint32 *)0x19FF0)
|
|
|
|
#define DID_0200_ADDR 0x1A000
|
|
#define DID_0201_ADDR 0x1A008
|
|
|
|
#define DID_F180_ADDR 0x19C20
|
|
#define DID_F193_ADDR 0x19C00
|
|
#define DID_F195_ADDR 0x19C10
|
|
|
|
extern KamData_t KamData;
|
|
extern uint8_t fsl_code_buf[0x480];
|
|
/***********************************************************************************************************************
|
|
Global functions
|
|
***********************************************************************************************************************/
|
|
|
|
#endif
|