# Makefile for arch-dependent kernel code .include HERE=${.CURDIR}/arch/${MACHINE_ARCH} .PATH: ${HERE} # objects we want unpaged from -lminlib MINLIB_OBJS_UNPAGED= get_bp.o get_bp.o: ${NETBSDSRCDIR}/lib/libminlib/${MACHINE_ARCH}/get_bp.S # objects we want unpaged from -lsys SYS_OBJS_UNPAGED=assert.o stacktrace.o assert.o: ${NETBSDSRCDIR}/lib/libsys/assert.c stacktrace.o: ${NETBSDSRCDIR}/lib/libsys/stacktrace.c # objects we want unpaged from -lminc MINC_OBJS_UNPAGED= atoi.o \ printf.o subr_prf.o \ strcmp.o strcpy.o strlen.o strncmp.o \ memcpy.o memmove.o memset.o \ udivdi3.o umoddi3.o qdivrem.o MINC_OBJS_UNPAGED+= __aeabi_ldiv0.o __aeabi_idiv0.o __aeabi_uldivmod.o divide.o divsi3.o udivsi3.o atoi.o: ${NETBSDSRCDIR}/lib/libminc/atoi.c printf.o: ${NETBSDSRCDIR}/sys/lib/libsa/printf.c subr_prf.o: ${NETBSDSRCDIR}/sys/lib/libsa/subr_prf.c memcpy.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/string/memcpy.S memmove.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/string/memmove.S memset.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/string/memset.S strlen.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/string/strlen.S strcpy.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/string/strcpy.S strcmp.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/string/strcmp.S #strcat.o: ${NETBSDSRCDIR}/common/lib/libc/string/strcat.c __aeabi_idiv0.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/gen/__aeabi_idiv0.c __aeabi_ldiv0.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/gen/__aeabi_ldiv0.c __aeabi_uldivmod.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/quad/__aeabi_uldivmod.S divide.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/gen/divide.S divsi3.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/gen/divsi3.S udivsi3.o: ${NETBSDSRCDIR}/common/lib/libc/arch/arm/gen/udivsi3.S # the following is required by pre_init.c strncmp.o: ${NETBSDSRCDIR}/common/lib/libc/string/strncmp.c # these are required by kprintn.o: udivdi3.o: ${NETBSDSRCDIR}/common/lib/libc/quad/udivdi3.c umoddi3.o: ${NETBSDSRCDIR}/common/lib/libc/quad/umoddi3.c qdivrem.o: ${NETBSDSRCDIR}/common/lib/libc/quad/qdivrem.c CPPFLAGS.__aeabi_idiv0.c+= -D_STANDALONE CPPFLAGS.__aeabi_ldiv0.c+= -D_STANDALONE # LSC: putchar and kputc have the same signature. A bit hackish. CPPFLAGS.subr_prf.c+= -Dputchar=kputc # Activate optional support, may be deactivated. CPPFLAGS.subr_prf.c+= -DLIBSA_PRINTF_LONGLONG_SUPPORT -DLIBSA_PRINTF_WIDTH_SUPPORT .include "bsp/ti/Makefile.inc" # some object files we give a symbol prefix (or namespace) of __k_unpaged_ # that must live in their own unique namespace. # .for unpaged_obj in head.o pre_init.o direct_tty_utils.o \ pg_utils.o klib.o utility.o arch_reset.o \ ${MINLIB_OBJS_UNPAGED} ${MINC_OBJS_UNPAGED} ${SYS_OBJS_UNPAGED} ${BSP_OBJS_UNPAGED} unpaged_${unpaged_obj}: ${unpaged_obj} ${OBJCOPY} --prefix-symbols=__k_unpaged_ ${.OBJDIR}/${unpaged_obj} $@ UNPAGED_OBJS += unpaged_${unpaged_obj} ORIG_UNPAGED_OBJS += ${unpaged_obj} .endfor CLEANFILES+= ${ORIG_UNPAGED_OBJS} SRCS+= mpx.S arch_clock.c arch_do_vmctl.c arch_system.c do_padconf.c \ exception.c hw_intr.c klib.S memory.c \ protect.c direct_tty_utils.c arch_reset.c \ pg_utils.c phys_copy.S phys_memset.S exc.S OBJS.kernel+= ${UNPAGED_OBJS} klib.o mpx.o head.o: procoffsets.h SRCS+= procoffsets.h PROCOFFSETSCF=procoffsets.cf .PATH: ${NETBSDSRCDIR}/include/arch/${MACHINE_ARCH}/include procoffsets.h: ${PROCOFFSETSCF} kernel.h proc.h stackframe.h archtypes.h ${_MKTARGET_CREATE} ${TOOL_CAT} ${HERE}/${PROCOFFSETSCF} | \ ${TOOL_GENASSYM} -- ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} >$@.tmp && \ mv -f $@.tmp $@ sconst.h: procoffsets.h apic_asm.o head.o klib.o mpx.o: sconst.h