Repostiory containing DAPLink source code with Reset Pin workaround for HANI_IOT board.

Upstream: https://github.com/ARMmbed/DAPLink

Committer:
Pawel Zarembski
Date:
Tue Apr 07 12:55:42 2020 +0200
Revision:
0:01f31e923fe2
hani: DAPLink with reset workaround

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Pawel Zarembski 0:01f31e923fe2 1 /**
Pawel Zarembski 0:01f31e923fe2 2 * @file flash_blob.c
Pawel Zarembski 0:01f31e923fe2 3 * @brief Flash algorithm for the lpc824
Pawel Zarembski 0:01f31e923fe2 4 *
Pawel Zarembski 0:01f31e923fe2 5 * DAPLink Interface Firmware
Pawel Zarembski 0:01f31e923fe2 6 * Copyright (c) 2009-2019, ARM Limited, All Rights Reserved
Pawel Zarembski 0:01f31e923fe2 7 * SPDX-License-Identifier: Apache-2.0
Pawel Zarembski 0:01f31e923fe2 8 *
Pawel Zarembski 0:01f31e923fe2 9 * Licensed under the Apache License, Version 2.0 (the "License"); you may
Pawel Zarembski 0:01f31e923fe2 10 * not use this file except in compliance with the License.
Pawel Zarembski 0:01f31e923fe2 11 * You may obtain a copy of the License at
Pawel Zarembski 0:01f31e923fe2 12 *
Pawel Zarembski 0:01f31e923fe2 13 * http://www.apache.org/licenses/LICENSE-2.0
Pawel Zarembski 0:01f31e923fe2 14 *
Pawel Zarembski 0:01f31e923fe2 15 * Unless required by applicable law or agreed to in writing, software
Pawel Zarembski 0:01f31e923fe2 16 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
Pawel Zarembski 0:01f31e923fe2 17 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
Pawel Zarembski 0:01f31e923fe2 18 * See the License for the specific language governing permissions and
Pawel Zarembski 0:01f31e923fe2 19 * limitations under the License.
Pawel Zarembski 0:01f31e923fe2 20 */
Pawel Zarembski 0:01f31e923fe2 21
Pawel Zarembski 0:01f31e923fe2 22 #include "flash_blob.h"
Pawel Zarembski 0:01f31e923fe2 23
Pawel Zarembski 0:01f31e923fe2 24 static const uint32_t LPC824_FLM[] = {
Pawel Zarembski 0:01f31e923fe2 25 0xE00ABE00, 0x062D780D, 0x24084068, 0xD3000040, 0x1E644058, 0x1C49D1FA, 0x2A001E52, 0x4770D1F2,
Pawel Zarembski 0:01f31e923fe2 26
Pawel Zarembski 0:01f31e923fe2 27 /*0x020*/ 0x47700a80, 0x21004841, 0x22016301, 0x63416342, 0x6b416342, 0xd0fc07c9L, 0x493c6382, 0x39402002,
Pawel Zarembski 0:01f31e923fe2 28 /*0x040*/ 0x20006008, 0x20004770, 0xb5f84770L, 0x20324c38, 0x2500444c, 0x4622261f, 0x4621c261, 0x4f353114,
Pawel Zarembski 0:01f31e923fe2 29 /*0x060*/ 0x91004620L, 0x696047b8, 0xd10a2800L, 0x46212034, 0x4831c161, 0x462060e0, 0x47b89900, 0x28006960,
Pawel Zarembski 0:01f31e923fe2 30 /*0x080*/ 0x2001d000, 0xb5f8bdf8L, 0xa844d29, 0x2032444d, 0x4629606c, 0x311460ac, 0x4e266028, 0x4628460f,
Pawel Zarembski 0:01f31e923fe2 31 /*0x0A0*/ 0x696847b0, 0xd10b2800L, 0x2034606c, 0x602860ac, 0x60e84821, 0x46284639, 0x696847b0, 0xd0002800L,
Pawel Zarembski 0:01f31e923fe2 32 /*0x0C0*/ 0xbdf82001L, 0x4614b5f8, 0xd10e0006L, 0x68206861, 0x184068e2, 0x188968a1, 0x69211840, 0x69611840,
Pawel Zarembski 0:01f31e923fe2 33 /*0x0E0*/ 0x69a11840, 0x42401840, 0x4d1161e0, 0x444d0ab0, 0x60682132, 0x60a86029, 0x31144629, 0x46284f0d,
Pawel Zarembski 0:01f31e923fe2 34 /*0x100*/ 0x47b89100, 0x28006968, 0x606ed10e, 0x60ac2033, 0x20016028, 0x60e80240, 0x61284807, 0x99004628L,
Pawel Zarembski 0:01f31e923fe2 35 /*0x120*/ 0x696847b8, 0xd0002800L, 0xbdf82001L, 0x40048040, 0x4, 0x1fff1ff1, 0x2ee0, 0x0,
Pawel Zarembski 0:01f31e923fe2 36 /*0x140*/
Pawel Zarembski 0:01f31e923fe2 37 };
Pawel Zarembski 0:01f31e923fe2 38
Pawel Zarembski 0:01f31e923fe2 39 /**
Pawel Zarembski 0:01f31e923fe2 40 * List of start and size for each size of flash sector
Pawel Zarembski 0:01f31e923fe2 41 * The size will apply to all sectors between the listed address and the next address
Pawel Zarembski 0:01f31e923fe2 42 * in the list.
Pawel Zarembski 0:01f31e923fe2 43 * The last pair in the list will have sectors starting at that address and ending
Pawel Zarembski 0:01f31e923fe2 44 * at address start + size.
Pawel Zarembski 0:01f31e923fe2 45 */
Pawel Zarembski 0:01f31e923fe2 46 static const sector_info_t sectors_info[] = {
Pawel Zarembski 0:01f31e923fe2 47 {0, 1024},
Pawel Zarembski 0:01f31e923fe2 48 };
Pawel Zarembski 0:01f31e923fe2 49
Pawel Zarembski 0:01f31e923fe2 50 static const program_target_t flash = {
Pawel Zarembski 0:01f31e923fe2 51 0x10000025, // Init
Pawel Zarembski 0:01f31e923fe2 52 0x10000047, // UnInit
Pawel Zarembski 0:01f31e923fe2 53 0x1000004B, // EraseChip
Pawel Zarembski 0:01f31e923fe2 54 0x10000087, // EraseSector
Pawel Zarembski 0:01f31e923fe2 55 0x100000C5, // ProgramPage
Pawel Zarembski 0:01f31e923fe2 56 0x0, // Verify
Pawel Zarembski 0:01f31e923fe2 57
Pawel Zarembski 0:01f31e923fe2 58 // static_base : base address is address of Execution Region PrgData in map file
Pawel Zarembski 0:01f31e923fe2 59 // to access global/static data
Pawel Zarembski 0:01f31e923fe2 60 // stack_pointer : Initial stack pointer
Pawel Zarembski 0:01f31e923fe2 61 {0x10000001, 0x10000200, 0x10001000}, // {breakpoint, static_base, stack_pointer}
Pawel Zarembski 0:01f31e923fe2 62
Pawel Zarembski 0:01f31e923fe2 63 0x10000400, // program_buffer
Pawel Zarembski 0:01f31e923fe2 64 0x10000000, // algo_start
Pawel Zarembski 0:01f31e923fe2 65 0x00000140, // algo_size
Pawel Zarembski 0:01f31e923fe2 66
Pawel Zarembski 0:01f31e923fe2 67 /*
Pawel Zarembski 0:01f31e923fe2 68 0x10000000 ---------------------- algo_start
Pawel Zarembski 0:01f31e923fe2 69 | FLASH ALGORITHM |
Pawel Zarembski 0:01f31e923fe2 70 0x10000001 | | breakpoint
Pawel Zarembski 0:01f31e923fe2 71 0x10000025 | | Init
Pawel Zarembski 0:01f31e923fe2 72 0x10000047 | | UnInit
Pawel Zarembski 0:01f31e923fe2 73 0x1000004b | | EraseChip
Pawel Zarembski 0:01f31e923fe2 74 0x10000087 | | EraseSector
Pawel Zarembski 0:01f31e923fe2 75 0x100000c5 | | ProgramPage
Pawel Zarembski 0:01f31e923fe2 76 | |
Pawel Zarembski 0:01f31e923fe2 77 ---------------------- algo_start + algo_size
Pawel Zarembski 0:01f31e923fe2 78 | unused |
Pawel Zarembski 0:01f31e923fe2 79 0x10000200 ---------------------- static_base
Pawel Zarembski 0:01f31e923fe2 80 | GLOBAL/STATIC DATA |
Pawel Zarembski 0:01f31e923fe2 81 | |
Pawel Zarembski 0:01f31e923fe2 82 0x10000400 ---------------------- program_buffer
Pawel Zarembski 0:01f31e923fe2 83 | DATA TO BE WRITTEN |
Pawel Zarembski 0:01f31e923fe2 84 | |
Pawel Zarembski 0:01f31e923fe2 85 ---------------------- program_buffer + ram_to_flash_bytes_to_be_written
Pawel Zarembski 0:01f31e923fe2 86 | unused |
Pawel Zarembski 0:01f31e923fe2 87 ----------------------
Pawel Zarembski 0:01f31e923fe2 88 | SPACE FOR STACK |
Pawel Zarembski 0:01f31e923fe2 89 0x10001000 ---------------------- stack_pointer
Pawel Zarembski 0:01f31e923fe2 90 | unused |
Pawel Zarembski 0:01f31e923fe2 91 ----------------------
Pawel Zarembski 0:01f31e923fe2 92 | 32 BYTES FOR IAP |
Pawel Zarembski 0:01f31e923fe2 93 0x10?????? ---------------------- CHIP MEMORY LIMIT
Pawel Zarembski 0:01f31e923fe2 94 */
Pawel Zarembski 0:01f31e923fe2 95
Pawel Zarembski 0:01f31e923fe2 96 LPC824_FLM, // image
Pawel Zarembski 0:01f31e923fe2 97
Pawel Zarembski 0:01f31e923fe2 98 512 // ram_to_flash_bytes_to_be_written
Pawel Zarembski 0:01f31e923fe2 99 };
Pawel Zarembski 0:01f31e923fe2 100