embed
=====
This example illustrates a simple C program, suitable for embedded
applications.
The main C program is contained in main.c. This has a main() function, which
calls subroutines to show the use of printf(), sprintf(), floating point
printf() and malloc(). This can be compiled/linked on its own and executed
in the semihosting environment (see build a below). Alternatively, the project
can be built as an embedded application with no semihosting (builds b & c).
This example can be built in three different ways, in increasing order of
complexity:
a. Non-embedded (semihosted), scatterloaded
b. Embedded, with ROM fixed at 0x0, scatterloaded
c. Embedded, ROM/RAM remapped, scatterloaded
For options b and c, all hard coded addresses are located in the scatterfile
To build the example, either:
- use the supplied batch files (build_a.bat, build_b.bat, build_c.bat), or
- use the supplied CodeWarrior project file (embed.mcp, with 3 targets:
Semihosted, EmbeddedScatter, EmbeddedScatterRemap), or
- create your own make files.
These create an ELF image (embed.axf) suitable for loading into an ARM
debugger. A Motorola32 ROM image (embed.m32) is also created, suitable
for loading into a target, for example, downloading into the flash memory
of an ARM Integrator board.
To convert it into an embeddable application, additional files are provided:
1. vectors.s contains exception vectors and exception handlers. Where there
is ROM fixed at 0x0 (build_b), these are hard-coded at 0x0.
Where ROM/RAM remapping occurs (build_c), these are copied from ROM to
RAM.
2. init.s performs ROM/RAM remapping (if required), initializes stack
pointers and interrupts for each mode, and finally branches to __main
in the C library (which eventually calls main()).
3. retarget.c implements a 'retarget' layer for low-level I/O. Typically,
this would contain your own target-dependent implementations of
fputc(), ferror(), etc. This example provides implementations of
fputc(), ferror(), _sys_exit(), _ttywrch() and
__user_initial_stackheap(). Here, semihosting SWIs are used to
display text onto the console of the host debugger. This mechanism is
portable across ARMulator, Angel and Multi-ICE.
Alternatively, to output characters from the serial port of an ARM
Integrator Board (see serial.c), use '#define USE_SERIAL_PORT' or
compile with '-DUSE_SERIAL_PORT'.
4. serial.c implements a simple (polled) RS232 serial driver for the ARM
Integrator Board. It outputs single characters on Serial
Port A at 38400 Baud, 8 bit, no parity, 1 stop bit. To monitor the
characters output, use a null-modem cable to connect Serial Port A to
an RS232 terminal or PC running a terminal emulator, e.g. HyperTerminal.
5. In addition the files stack.s and heap.s are used to create dummy variables
which are placed in memory by the scatter load file. These can then be used
to place the stack and heap respectively.
6. Finally uart.c instantiates a struction corresponding to the layout of
the uart registers. This structure is located in memory by the scatter load
file.
To ensure that no functions which use semihosting SWIs are linked in from the
C library, __use_no_semihosting_swi is used for the 2 'embeddable' builds.
The 3 different builds can be executed either on the ARMulator, or on real
hardware (e.g. Integrator board via Multi-ICE). To run the examples on real
hardware, please note:
i. For Semihosted (build_a) build targets, set $top_of_memory to a suitable
value via the debugger. The (unexpanded) Integrator CM has 256KB of SSRAM
fitted, so set $top_of_memory=0x40000. If additional SDRAM is fitted, set
$top_of_memory appropriately. It is not necessary to set $top_of_memory for
the other builds, because they implement __user_initial_stackheap().
ii. For EmbeddedScatter (build_b.bat) and EmbeddedScatterRemap (build_c.bat)
build targets, set $vector_catch=0 to prevent exceptions being caught, and to
free up a watchpoint unit in the EmbeddedICE Logic.
iii. EmbeddedScatterRemap (build_c.bat) is intended to be downloaded into Flash
(see below).
Building for Thumb
------------------
The supplied batch files (build_a.bat, build_b.bat, build_c.bat) and supplied
CodeWarrior project files build ARM-only versions of this code.
To build ARM/Thumb interworking versions of this example, where the bulk
of the C code is compiled for Thumb, change the invocations of 'armcc'
into 'tcc -apcs /interwork', so that e.g. build_c.bat becomes:
armasm -g vectors.s
armasm -g -PD "ROM_RAM_REMAP SETL {TRUE}" init.s
armasm -g stack.s
armasm -g heap.s
REM Use the following two lines to build without using the serial port.
tcc -apcs /interwork -c -g -O1 main.c -DEMBEDDED -DROM_RAM_REMAP
tcc -apcs /interwork -c -g -O1 retarget.c
REM Use the following two lines to build using the serial port.
REM tcc -apcs /interwork -c -g -O1 main.c -DEMBEDDED -DROM_RAM_REMAP -DUSE_SERIAL_PORT
REM tcc -apcs /interwork -c -g -O1 retarget.c -DUSE_SERIAL_PORT
tcc -apcs /interwork -c -g -O1 uart.c -I..\include
tcc -apcs /interwork -c -g -O1 serial.c -I..\include
armlink vectors.o init.o main.o retarget.o uart.o serial.o stack.o heap.o -scatter scat_c.scf -o embed.axf -entry 0x24000000 -info totals -info unused
fromelf embed.axf -bin -o embed.bin
fromelf embed.axf -m32 -o embed.m32
Downloading to Flash
--------------------
Follow the instrictions below to download the 'Embedded, scatterloaded'
examples 'build_b' and 'build_c' to the flash memory of an ARM Integrator
board, so that you can execute/debug the image at source level.
Use the debugger's File->Flash-download feature, which uses flash.li/.bi.
This requires a plain binary image to be built with:
fromelf embed.axf -bin -o embed.bin
See 'AXD and armsd Debuggers Guide', Appendix D, "Using the Flash Downloader".
Alternatively:
Follow the steps 1-8 below to download using the Integrator's Boot Loader:
These steps require a terminal emulator such as 'HyperTerminal'.
1. Connect the Integrator board to the host computer using a null modem
serial cable.
2. Invoke the terminal emulator and ensure it has the following settings:
- Baud rate 38400
- Data bits 8
- No parity
- Stop bits 1
- Flow control Xon/Xoff
3. Ensure switches 1 and 4 on the Integrator board are in the 'ON'
position and reset the board.
4. Enter 'l' to load flash image at the Boot Loader prompt in the terminal
window.
5. Transfer the 'embed.m32' file via the serial cable using the terminal
tools. In Hyperterminal this is done by selecting
'Transfer->Send Text File' from the menu and navigating to the
embed.m32 file.
6. Once the image has loaded (approx 25 seconds) terminate the flash
transfer by pressing Ctrl-C.
7. Ensure switch 1 is returned to the 'OFF' position.
8. The image is now present in flash and will be executed when the board
is reset. Output from the image will be sent to the terminal window
only if the image was built using the -USE_SERIAL_PORT option.
Otherwise output must be viewed using AXD with the image debug
symbols via a connection to the board such as Multi-Ice.
Memory Maps
-----------
The following diagrams illustrate the Memory Maps for this example, for each
different build:
build_a.bat:
0x08000000 (ARMulator) or
+----------+ 0x00040000 (Integrator board)
| stack |
| VV |
~ ~
| ^^ |
| heap |
+----------+ Image$$ZI$$Limit
| ZI data |
+----------+
| RW data |
+----------+
| |
| |
| program |
| (RO+RW) |
| |
| |
+----------+ 0x8000
build_b.bat
--- +----------+ 0x280800
没有合适的资源?快使用搜索试试~ 我知道了~
wav.rar_ADS1.2_ads_wav
共50个文件
h:34个
s:6个
txt:3个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 163 浏览量
2022-09-24
13:08:43
上传
评论
收藏 425KB RAR 举报
温馨提示
ADS1.2 开发环境下开发的音频程序代码,
资源推荐
资源详情
资源评论
收起资源包目录
wav.rar (50个子文件)
音频实验
init
stack.s 393B
heap.s 224B
scat_rom.scf 2KB
retarget.c 2KB
scat_ram.scf 2KB
isr_address.s 2KB
readme.txt 10KB
1.wav 438KB
Lib
ucos_lib.a 242KB
SRC
Main.c 4KB
INC
DRV
EXIO.h 304B
MCP2510.h 6KB
display.h 6KB
lcd320.h 936B
DirectDisplay.h 4KB
IIS-S3C44B0.h 3KB
can.h 2KB
Loadfile.h 247B
zlg7289.h 1KB
flash.h 1KB
AD.h 532B
rtc.h 800B
Figure.h 698B
KeyBoard16.h 127B
tchScr.h 887B
Ustring.h 285B
OSFile.h 3KB
BITOPS.H 879B
DEF.H 444B
Maro.h 164B
drv.h 226B
STARTUP
44BINIT.S 11KB
OPTION.S 1003B
OPTION.H 2KB
44B.H 15KB
MEMCFG.S 3KB
UCOS-II
CHRONOS.H 46KB
uhal
uhal.h 2KB
Uart.h 331B
ISR.H 1KB
includes.h 1KB
OS_CFG.H 7KB
ADD
osaddition.h 163B
Control.h 6KB
OSAddTask.h 161B
List.h 352B
OSMessage.h 880B
Exp13.mcp 152KB
readme.txt 46B
www.pudn.com.txt 218B
共 50 条
- 1
资源评论
周楷雯
- 粉丝: 80
- 资源: 1万+
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功