커널에서 표준라이브러리 함수 쓰기...
미치겠습니다. 지금 계획이 객체지향적으로 커널을 구성하려고하는데
구성하기는 커녕 c++ 표준 라이브러리는 커녕 c도 제대로 활용하지 못하고 있습니다.
현재 상황은 이렇습니다
커널을 구성하고 cpp 로 된 커널에서 sprintf 함수를 불러오는데
제가 변수들의 링킹을 생각해서(전에도 질문했었는데요, 실제로 커널을 부트로더에다가 더할때
copy 로 붙이기 때문...) 커널의 시작을 실제 부트됬을때 로딩되는 주소로 지정하고
(ld 에 -Ttext 옵션으로말입니다) 부팅을 했더니 자꾸 비정상 종료가 되더군요
반면에 -Ttext 0 을 주고 하면 실제로 변수같은건 참조하지 못하지만 돌아가기는 돌아가구요
도대체 어떤게 문제인지 감조차 못잡고 있는 상황인데 ㅠㅠ 조언 부탁드립니다
소스에는 정말 특별한게 없어서 혹시나 참조하실까봐 makefile 올려봅니다
TOOLPATH = tools\
MAKE = $(TOOLPATH)make.exe
NASM = nasm\nasm.exe
EDIMG = tools\edimg.exe
COPY = copy
DEL = del
GCC = gcc
STRIP = strip
LD = ld
GPP = g++ -Wall
#디폴트 동작
default :
$(MAKE) main.img
#파일 생성 규칙
ipl.bin : ipl.asm Makefile
$(NASM) ipl.asm -o ipl.bin
OsAsm.o : OsAsm.asm Makefile
$(NASM) -f coff OsAsm.asm -o OsAsm.o
kernel.o : kernel.cpp Makefile
$(GPP) -c -fno-rtti kernel.cpp
#-fomit-frame-pointer -mpreferred-stack-boundary=1 -ffunction-sections (원하는 함수만 링크, ld 에서 -gc-function과 함께)
view.o : view.cpp Makefile
$(GPP) -c -fno-rtti view.cpp
model.o : Model.cpp Makefile
$(GPP) -c -fno-rtti model.cpp
cppfunction.o : CppFunction.cpp Makefile
$(GPP) -c -fno-rtti CppFunction.cpp
# 여기까지 각자 개별 컴파일할때
# kernel.o view.o model.o cppfunction.o
OsTotal.bin : OsAsm.o kernel.o view.o model.o cppfunction.o Makefile
# $(GPP) -o OsTotal.o -fno-rtti -Wl,-Ttext,0 -Wl,-e,main -Wl,-Map,ostotal.map kernel.cpp view.cpp model.cpp osasm.o
$(LD) -o Ostotal.o -Map ostotal.map -Ttext 0xc400 -Ttext-segment 2 --dynamic-list-cpp-new -static -e main -static kernel.o view.o model.o osasm.o cppfunction.o character.obj -lmsvcrt
# c:\mingw\lib\crt2.o c:\mingw\lib\gcc\mingw32\4.5.2\crtbegin.o -lstdc++ -lmingw32 -lgcc -lmoldname -lmingwex -lmsvcrt -luser32 -lkernel32 -ladvapi32 -lshell32 -Lc:\mingw\lib\gcc\mingw32\4.5.2 -lgcc_s c:\mingw\lib\gcc\mingw32\4.5.2\crtend.o
objdump -S ostotal.o > 1.txt
# $(LD) -o Ostotal.o -Map ostotal2.map -Ttext 0 -e main kernel.o view.o model.o osasm.o ar\new_op.o ar\new_handler.o
objcopy -R .note -R .comment -S -O binary OsTotal.o OsTotal.bin
OsMain.bin : OsMain.asm Makefile
$(NASM) OsMain.asm -o OsMain.bin
#OsMain.bin = 512byte (0x200)
#ipl.bin = 5376byte (0x1500)
#kernel.bin 의 로드지점은 부트로더 0x8000 + osmain.sys 시작 0x4200 + osmain 0x200 = 0xc400
OsMain.sys : OsMain.bin OsTotal.bin Makefile
$(COPY) /B OsMain.bin+OsTotal.bin OsMain.sys
main.img : ipl.bin OsMain.sys Makefile
$(EDIMG) imgin:StandImg.ima wbinimg src:ipl.bin len:512 from:0 to:0 \
copy from:OsMain.sys to:@: \
imgout:main.img
# 커맨드
img :
$(MAKE) main.img
run :
$(MAKE) del
$(MAKE) img
$(COPY) main.img tools\qemu\fdimage0.bin
$(MAKE) -C tools\qemu
test :
$(COPY) main.img tools\qemu\fdimage0.bin
$(MAKE) -C tools\qemu
del :
$(DEL) *.img
$(DEL) *.bin
$(DEL) *.sys
$(DEL) *.lst
$(DEL) *.o
댓글 달기