Repostiory containing DAPLink source code with Reset Pin workaround for HANI_IOT board.
Upstream: https://github.com/ARMmbed/DAPLink
source/hic_hal/FlashOS.h
- Committer:
- Pawel Zarembski
- Date:
- 2020-04-07
- Revision:
- 0:01f31e923fe2
File content as of revision 0:01f31e923fe2:
/** * @file FlashOS.h * @brief * * DAPLink Interface Firmware * Copyright (c) 2009-2016, ARM Limited, All Rights Reserved * SPDX-License-Identifier: Apache-2.0 * * Licensed under the Apache License, Version 2.0 (the "License"); you may * not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef FLASHOS_H #define FLASHOS_H #include <stdint.h> #ifdef __cplusplus extern "C" { #endif #define VERS 1 // Interface Version 1.01 #define NAME_MAX 128 // Max size of the routine name #define PAGE_MAX 65536 // Max Page Size for Programming #define SECTOR_NUM 512 // Max Number of Sector Items #define SECTOR_END 0xFFFFFFFF, 0xFFFFFFFF // FlashDevice.devType interface mechanism #define UNKNOWN 0 #define ONCHIP 1 #define EXT8BIT 2 #define EXT16BIT 3 #define EXT32BIT 4 #define EXTSPI 5 /** @struct FlashSector @brief A structure to describe the size and start address of a flash sector */ struct FlashSector { uint32_t szSector; /*!< Sector Size in Bytes */ uint32_t adrSector; /*!< Address of Sector */ }; /** @struct FlashDevice @brief A structure to describe particulars of a flash memory sub-system and requirements of the driver */ struct FlashDevice { uint16_t vers; /*!< Version Number and Architecture */ char devName[NAME_MAX]; /*!< Device Name and Description */ uint16_t devType; /*!< Device Type: ONCHIP, EXT8BIT, EXT16BIT, ... */ uint32_t devAdr; /*!< Default Device Start Address */ uint32_t szDev; /*!< Total Size of Device */ uint32_t szPage; /*!< Programming Page Size */ uint32_t res; /*!< Reserved for future Extension */ uint8_t valEmpty; /*!< Content of Erased Memory */ uint32_t toProg; /*!< Time Out of Program Page Function */ uint32_t toErase; /*!< Time Out of Erase Sector Function */ struct FlashSector sectors[SECTOR_NUM]; /*!< Entries to describe flash memory layout */ }; #ifdef __cplusplus } #endif #endif