X-Git-Url: http://www.aleph1.co.uk/gitweb/?p=yaffs2.git;a=blobdiff_plain;f=direct%2Fpython%2FMakefile;h=c428732b495028acf1f6d1bc44be0c85e3e9601b;hp=98b726c38bae0f74f90fa9486b3197e7c830d093;hb=6ee253300224f1f146931cf7822f57059f600f4b;hpb=c958ef331148b55adf0289bf6bfaa26b1ef7c7e0 diff --git a/direct/python/Makefile b/direct/python/Makefile index 98b726c..c428732 100644 --- a/direct/python/Makefile +++ b/direct/python/Makefile @@ -3,7 +3,7 @@ # # YAFFS: Yet another Flash File System. A NAND-flash specific file system. # -# Copyright (C) 2003 Aleph One Ltd. +# Copyright (C) 2003-2010 Aleph One Ltd. # # # Created by Charles Manning @@ -14,75 +14,101 @@ # # NB Warning this Makefile does not include header dependencies. # -# $Id: Makefile,v 1.1 2009-10-08 01:58:52 charles Exp $ +# $Id: Makefile,v 1.6 2010-02-17 00:51:15 charles Exp $ #EXTRA_COMPILE_FLAGS = -DYAFFS_IGNORE_TAGS_ECC -CFLAGS = -DCONFIG_YAFFS_DIRECT -DCONFIG_YAFFS_SHORT_NAMES_IN_RAM -DCONFIG_YAFFS_YAFFS2 +CFLAGS = -DCONFIG_YAFFS_DIRECT -DCONFIG_YAFFS_YAFFS2 CFLAGS += -DCONFIG_YAFFS_PROVIDE_DEFS -DCONFIG_YAFFSFS_PROVIDE_VALUES -DNO_Y_INLINE CFLAGS += -Wall -g $(EXTRA_COMPILE_FLAGS) -Wstrict-aliasing #CFLAGS += -fno-strict-aliasing -CFLAGS += -O0 +CFLAGS += -O0 -fPIC #CFLAGS += -DVALGRIND_TEST #CFLAGS+= -Wshadow -Wpointer-arith -Wwrite-strings -Wstrict-prototypes -Wmissing-declarations #CFLAGS+= -Wmissing-prototypes -Wredundant-decls -Wnested-externs -Winline -COMMONTESTOBJS = yaffscfg2k.o yaffs_ecc.o yaffs_fileem.o yaffs_fileem2k.o yaffsfs.o yaffs_guts.o \ +COMMONTESTOBJS = yaffscfg2k.o yaffs_osglue.o yaffs_hweight.o\ + yramsim.o yaffs_fileem2k.o\ + yaffs_nandif.o yaffs_attribs.o \ + yaffsfs.o yaffs_ecc.o yaffs_guts.o \ yaffs_packedtags1.o yaffs_ramdisk.o yaffs_ramem2k.o \ - yaffs_tagscompat.o yaffs_packedtags2.o yaffs_tagsvalidity.o yaffs_nand.o \ + yaffs_tagscompat.o yaffs_packedtags2.o yaffs_nand.o \ yaffs_checkptrw.o yaffs_qsort.o\ - yaffs_norif1.o ynorsim.o - - -YAFFSTESTOBJS = $(COMMONTESTOBJS) yaffs_wrap.o yaffs_swig_helper.o - - -ALLOBJS = $(sort $(YAFFSTESTOBJS)) - -YAFFSSYMLINKS = devextras.h yaffs_ecc.c yaffs_ecc.h yaffs_guts.c yaffs_guts.h yaffsinterface.h yportenv.h yaffs_tagscompat.c yaffs_tagscompat.h \ - yaffs_packedtags1.c yaffs_packedtags1.h yaffs_packedtags2.c yaffs_packedtags2.h yaffs_nandemul2k.h \ - yaffs_nand.c yaffs_nand.h yaffs_getblockinfo.h \ - yaffs_tagsvalidity.c yaffs_tagsvalidity.h yaffs_checkptrw.h yaffs_checkptrw.c \ - yaffs_qsort.c yaffs_qsort.h - -YAFFSDIRECTSYMLINKS = yaffscfg2k.c yaffs_fileem2k.c yaffsfs.c yaffs_flashif.h yaffs_flashif2.h\ - yaffs_fileem2k.h yaffsfs.h yaffs_malloc.h yaffs_ramdisk.h ydirectenv.h \ - yaffscfg.h yaffs_fileem.c yaffs_flashif.c yaffs_ramdisk.c yaffs_ramem2k.c\ - yaffs_norif1.c yaffs_norif1.h ynorsim.c ynorsim.h \ - yaffs_nandif.c yaffs_nandif.h - - -SYMLINKS = $(YAFFSSYMLINKS) $(YAFFSDIRECTSYMLINKS) - -all: _yaffs.so - -yaffs_wrap.c: yaffs.i yaffsfs_for_swig.h - swig -python yaffs.i - -yaffsfs_for_swig.h: yaffsfs.h - cat yaffsfs.h | sed -e "s/YCHAR/char/g" | sed -e "s/YUCHAR/unsigned char/g" | sed -e "s/struct yaffs_stat/struct yaffs_stat_struct/g" > $@ - -$(ALLOBJS): %.o: %.c - gcc -c $(CFLAGS) -I/usr/include/python2.6/ -o $@ $< - - -$(YAFFSSYMLINKS): - ln -s ../../$@ $@ + yaffs_nameval.o \ + yaffs_summary.o \ + yaffs_allocator.o \ + yaffs_norif1.o ynorsim.o \ + yaffs_bitmap.o \ + yaffs_verify.o \ + yaffs_yaffs1.o yaffs_yaffs2.o \ + yaffs_error.o + + +YAFFSLIBOBJS = $(COMMONTESTOBJS) yaffs_python_helper.o + + + +YAFFS_SOURCES = yaffs_ecc.c yaffs_ecc.h yaffs_guts.c yaffs_guts.h yaffs_tagscompat.c yaffs_tagscompat.h \ + yaffs_packedtags1.c yaffs_packedtags1.h yaffs_packedtags2.c yaffs_packedtags2.h \ + yaffs_nand.c yaffs_nand.h yaffs_getblockinfo.h \ + yaffs_checkptrw.h yaffs_checkptrw.c \ + yaffs_summary.c yaffs_summary.h \ + yaffs_nameval.c yaffs_nameval.h yaffs_attribs.h \ + yaffs_trace.h \ + yaffs_allocator.c yaffs_allocator.h \ + yaffs_yaffs1.c yaffs_yaffs1.h \ + yaffs_yaffs2.c yaffs_yaffs2.h \ + yaffs_bitmap.c yaffs_bitmap.h \ + yaffs_verify.c yaffs_verify.h + + +YAFFSDIRECTSYMLINKS = yaffsfs.c yaffsfs.h yaffscfg.h yaffs_osglue.h ydirectenv.h \ + yaffs_flashif.c yaffs_flashif.h yaffs_flashif2.h yaffs_list.h \ + yaffs_nandif.c yaffs_nandif.h yaffs_qsort.c yaffs_nandemul2k.h \ + yportenv.h yaffs_attribs.c \ + yaffs_hweight.c yaffs_hweight.h \ + yaffs_error.c + +DIRECTEXTRASYMLINKS = yaffscfg2k.c yaffs_fileem2k.c yaffs_fileem2k.h\ + yaffs_fileem.c yaffs_norif1.c yaffs_norif1.h \ + yaffs_ramdisk.c yaffs_ramdisk.h yaffs_ramem2k.c \ + yaffsnewcfg.c yramsim.c yramsim.h \ + ynorsim.h ynorsim.c yaffs_osglue.c + +ALL_SOURCES = $(YAFFS_SOURCES) $(YAFFSDIRECTSYMLINKS) $(DIRECTEXTRASYMLINKS) + +all: libyaffsfs.so + + +$(YAFFSLIBOBJS): %.o: %.c + gcc -c $(CFLAGS) -o $@ $< + +$(YAFFS_SOURCES): + sed ../../$@ \ + -e "s/strcat/yaffs_strcat/g" \ + -e "s/strcpy/yaffs_strcpy/g" \ + -e "s/strncpy/yaffs_strncpy/g" \ + -e "s/strnlen/yaffs_strnlen/g" \ + -e "s/strcmp/yaffs_strcmp/g" \ + -e "s/strncmp/yaffs_strncmp/g" >$@ + $(YAFFSDIRECTSYMLINKS): ln -s ../$@ $@ +$(DIRECTEXTRASYMLINKS): + ln -s ../basic-test/$@ $@ -_yaffs.so: $(SYMLINKS) yaffs_wrap.c $(ALLOBJS) - gcc -shared $(ALLOBJS) -o $@ +libyaffsfs.so: $(ALL_SOURCES) $(YAFFSLIBOBJS) + gcc -shared $(YAFFSLIBOBJS) -o $@ clean: - rm -f _yaffs.so yaffs.py yaffs.pyc yaffs_wrap.c $(ALLOBJS) core $(YAFFSSYMLINKS) $(YAFFSDIRECTSYMLINKS) - rm -f *.c.* - rm -f yaffsfs_for_swig.h + rm -f $(YAFFSLIBOBJS) core $(ALL_SOURCES) + rm -f libyaffsfs.so + rm -f *.pyc