summaryrefslogtreecommitdiffstats
path: root/make/custom/ts_386ex.cfg
blob: 8467d176b6abbc6bba03527983fe58615b6b2117 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#
#  Config file for the ts-386ex BSP
#
#  $Id$
#

include $(RTEMS_ROOT)/make/custom/default.cfg

RTEMS_CPU=i386
RTEMS_CPU_MODEL=i386_nofp

# This is the actual bsp directory used during the build process.
RTEMS_BSP_FAMILY=ts_386ex

#  This contains the compiler options necessary to select the CPU model
#  and (hopefully) optimize for it. Enables software floating-point
#  emulation since we don't have a i387 co-processor.
#
CPU_CFLAGS =-msoft-float -mno-fp-ret-in-387

# optimize flag: typically -0, could use -O4 or -fast
# -O4 is ok for RTEMS
# -fomit-frame-pointer breaks debugging and C++ exceptions
CFLAGS_OPTIMIZE_V= -O4 

#  This section makes the target dependent options file.

#  NDEBUG (C library)
#     if defined asserts do not generate code.  This is commonly used
#     as a command line option.
#
#  RTEMS_TEST_NO_PAUSE (RTEMS tests)
#     do not pause between screens of output in the rtems tests
#
#  BSP_DEBUG (BSP)
#     Enables some debugging in the BSP package.
#
#  LOAD_RTC_AT_START (BSP)
#     Initialize RTC and load into system clock at startup. This will break
#     some tests.

define make-target-options
	@echo "/* #define NDEBUG 1 */ "			>>$@
	@echo "#define RTEMS_TEST_NO_PAUSE 1"		>>$@
	@echo "/* #define UARTDEBUG  1 */"			>>$@
	@echo "/* #define BSP_DEBUG  1 */"			>>$@
	@echo "#define LOAD_RTC_AT_START  1"		>>$@
endef

#  Something like this should produce a map file but this does not work.

#     -Xlinker "-Map $(basename $@).map" $(LINK_OBJS)
#
#  This is a good way to get debug information.  The rdmp file is large
#  though (1.9 Mb for hello) and greatly slows the build process.
# $(OBJDUMP) -x -m i386 -d $(basename $@).coff > $(basename $@).rdmp

# The following are definitions of make-exe which will work using ld as
# is currently required.  It is expected that as of gcc 2.8, the end user
# will be able to override parts of the compilers specs and link using gcc.

ifeq ($(RTEMS_USE_GCC272),yes)
define make-exe
	$(LD) $(LDFLAGS) -N -T $(LINKCMDS) -o $(basename $@).coff \
	    -noinhibit-exec -Map $(basename $@).map \
	    $(START_FILE) $(LINK_OBJS) --start-group $(LINK_LIBS) --end-group
	$(OBJCOPY) -O srec $(basename $@).coff $(basename $@).i
	$(SED) -e 's/.$$//' -e '/^S0/d' $(basename $@).i | \
	          $(PACKHEX) > $(basename $@).exe
	$(NM) -g -n $(basename $@).coff > $(basename $@).num
	$(SIZE) $(basename $@).coff
endef
else
define make-exe
	$(LINK.c) $(AM_CFLAGS) $(AM_LDFLAGS) -o $(basename $@).elf \
	    $(LINK_OBJS) $(LINK_LIBS)
	$(OBJCOPY) -O binary $(basename $@).elf $(basename $@).exe
	$(NM) -g -n $(basename $@).elf > $(basename $@).num
	$(SIZE) $(basename $@).elf
endef
endif

# Miscellaneous additions go here