1 /******************************************************************************
2 *                                                                             *
3 * License Agreement                                                           *
4 *                                                                             *
5 * Copyright (c) 2005 Altera Corporation, San Jose, California, USA.           *
6 * All rights reserved.                                                        *
7 *                                                                             *
8 * Permission is hereby granted, free of charge, to any person obtaining a     *
9 * copy of this software and associated documentation files (the "Software"),  *
10 * to deal in the Software without restriction, including without limitation   *
11 * the rights to use, copy, modify, merge, publish, distribute, sublicense,    *
12 * and/or sell copies of the Software, and to permit persons to whom the       *
13 * Software is furnished to do so, subject to the following conditions:        *
14 *                                                                             *
15 * The above copyright notice and this permission notice shall be included in  *
16 * all copies or substantial portions of the Software.                         *
17 *                                                                             *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR  *
19 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,    *
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
21 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER      *
22 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING     *
23 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER         *
24 * DEALINGS IN THE SOFTWARE.                                                   *
25 *                                                                             *
26 *                                                                             *
27 * Altera does not recommend, suggest or require that this reference design    *
28 * file be used in conjunction or combination with any other product.          *
29 ******************************************************************************/
30 
31 #include "alt_types.h"
32 
33 /*
34  * This macro is used to load code/data from its load address to its
35  * execution address for a given section. The section name is the input
36  * argument. Note that a leading '.' is assumed in the name. For example
37  * to load the section .onchip_ram, use:
38  *
39  * ALT_LOAD_SECTION_BY_NAME(onchip_ram);
40  *
41  * This requires that the apropriate linker symbols have been generated
42  * for the section in question. This will be the case if you are using the
43  * default linker script.
44  */
45 
46 #define ALT_LOAD_SECTION_BY_NAME(name)                         \
47   {                                                            \
48     extern void _alt_partition_##name##_start;                 \
49     extern void _alt_partition_##name##_end;                   \
50     extern void _alt_partition_##name##_load_addr;             \
51                                                                \
52     alt_load_section(&_alt_partition_##name##_load_addr,       \
53                      &_alt_partition_##name##_start,           \
54                      &_alt_partition_##name##_end);            \
55   }
56 
57 /*
58  * Function used to load an individual section from flash to RAM.
59  *
60  * There is an implicit assumption here that the linker script will ensure
61  * that all sections are word aligned.
62  *
63  */
64 
alt_load_section(alt_u32 * from,alt_u32 * to,alt_u32 * end)65 static void ALT_INLINE alt_load_section (alt_u32* from,
66                                          alt_u32* to,
67                                          alt_u32* end)
68 {
69   if (to != from)
70   {
71     while( to != end )
72     {
73       *to++ = *from++;
74     }
75   }
76 }
77