alt_load.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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. * This agreement shall be governed in all respects by the laws of the State *
  27. * of California and by the laws of the United States of America. *
  28. * *
  29. * Altera does not recommend, suggest or require that this reference design *
  30. * file be used in conjunction or combination with any other product. *
  31. ******************************************************************************/
  32. #include "alt_types.h"
  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. #define ALT_LOAD_SECTION_BY_NAME(name) \
  46. { \
  47. extern void _alt_partition_##name##_start; \
  48. extern void _alt_partition_##name##_end; \
  49. extern void _alt_partition_##name##_load_addr; \
  50. \
  51. alt_load_section(&_alt_partition_##name##_load_addr, \
  52. &_alt_partition_##name##_start, \
  53. &_alt_partition_##name##_end); \
  54. }
  55. /*
  56. * Function used to load an individual section from flash to RAM.
  57. *
  58. * There is an implicit assumption here that the linker script will ensure
  59. * that all sections are word aligned.
  60. *
  61. */
  62. static void ALT_INLINE alt_load_section (alt_u32* from,
  63. alt_u32* to,
  64. alt_u32* end)
  65. {
  66. if (to != from)
  67. {
  68. while( to != end )
  69. {
  70. *to++ = *from++;
  71. }
  72. }
  73. }