mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 08:19:38 -04:00 
			
		
		
		
	make, some cleanup, slightly better support for legacy dingux
This commit is contained in:
		
							parent
							
								
									4d4bea1c5f
								
							
						
					
					
						commit
						3901ab970d
					
				
					 1 changed files with 26 additions and 22 deletions
				
			
		
							
								
								
									
										48
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										48
									
								
								Makefile
									
										
									
									
									
								
							|  | @ -22,7 +22,7 @@ else # NO_CONFIG_MAK | ||||||
| config.mak: | config.mak: | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| # This is actually needed, believe me.
 | # This is actually needed, believe me - one bit is used as a flag in some tables
 | ||||||
| # If you really have to disable this, set NO_ALIGN_FUNCTIONS elsewhere.
 | # If you really have to disable this, set NO_ALIGN_FUNCTIONS elsewhere.
 | ||||||
| ifndef NO_ALIGN_FUNCTIONS | ifndef NO_ALIGN_FUNCTIONS | ||||||
| CFLAGS += -falign-functions=2 | CFLAGS += -falign-functions=2 | ||||||
|  | @ -83,25 +83,34 @@ endif | ||||||
| -include Makefile.local | -include Makefile.local | ||||||
| 
 | 
 | ||||||
| ifeq "$(PLATFORM)" "opendingux" | ifeq "$(PLATFORM)" "opendingux" | ||||||
| opk: $(TARGET).opk |  | ||||||
| 
 | 
 | ||||||
| $(TARGET).opk: $(TARGET) | # TODO this should somehow go to the platform/opendingux directory?
 | ||||||
| 	$(RM) -rf .opk_data | .od_data: $(TARGET) | ||||||
| 	cp -r platform/opendingux/data .opk_data | 	$(RM) -rf .od_data | ||||||
| 	cp $< .opk_data/PicoDrive | 	cp -r platform/opendingux/data .od_data | ||||||
| 	$(STRIP) .opk_data/PicoDrive | 	cp $< .od_data/PicoDrive | ||||||
| 	mksquashfs .opk_data $@ -all-root -noappend -no-exports -no-xattrs | 	$(STRIP) .od_data/PicoDrive | ||||||
| 	cd .opk_data && zip -9 -r $(TARGET).zip * |  | ||||||
| 
 | 
 | ||||||
| all: opk | ifneq (,$(filter %__OPENDINGUX__, $(CFLAGS))) | ||||||
| 
 | # "legacy" opendingux without opk support
 | ||||||
| OBJS += platform/opendingux/inputmap.o | $(TARGET)-dge.zip: .od_data | ||||||
| 
 | 	rm -f .od_data/default.*.desktop | ||||||
| ifneq (,$(filter %__GCW0__ %__RG350__, $(CFLAGS))) | 	cd .od_data && zip -9 -r ../$@ * | ||||||
| CFLAGS += -DMIPS_USE_SYNCI # clear_cache uses SYNCI instead of a syscall | all: $(TARGET)-dge.zip | ||||||
|  | else | ||||||
|  | $(TARGET).opk: .od_data | ||||||
|  | 	rm -f .od_data/PicoDrive.dge | ||||||
|  | 	mksquashfs .od_data $@ -all-root -noappend -no-exports -no-xattrs | ||||||
|  | all: $(TARGET).opk | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
|  | ifneq (,$(filter %__GCW0__ %__RG350__, $(CFLAGS))) | ||||||
|  | CFLAGS += -DMIPS_USE_SYNCI # mips32r2 clear_cache uses SYNCI instead of syscall | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | OBJS += platform/opendingux/inputmap.o | ||||||
| use_inputmap ?= 1 | use_inputmap ?= 1 | ||||||
|  | 
 | ||||||
| # OpenDingux is a generic platform, really.
 | # OpenDingux is a generic platform, really.
 | ||||||
| PLATFORM := generic | PLATFORM := generic | ||||||
| endif | endif | ||||||
|  | @ -238,10 +247,6 @@ endif | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq (1,$(use_libchdr)) | ifeq (1,$(use_libchdr)) | ||||||
| # yuck, cmake looks like a nightmare to embed in a multi-platform make env :-/
 |  | ||||||
| # Moreover, libchdr uses -flto which apparently prevents static library linking.
 |  | ||||||
| # Reference all source files directly and hope for the best. Tested on linux,
 |  | ||||||
| # might not work on other platforms, and misses autodetected optimizations.
 |  | ||||||
| CFLAGS += -DUSE_LIBCHDR | CFLAGS += -DUSE_LIBCHDR | ||||||
| 
 | 
 | ||||||
| # chdr
 | # chdr
 | ||||||
|  | @ -250,7 +255,6 @@ CHDR_OBJS += $(CHDR)/src/libchdr_chd.o $(CHDR)/src/libchdr_cdrom.o | ||||||
| CHDR_OBJS += $(CHDR)/src/libchdr_flac.o | CHDR_OBJS += $(CHDR)/src/libchdr_flac.o | ||||||
| CHDR_OBJS += $(CHDR)/src/libchdr_bitstream.o $(CHDR)/src/libchdr_huffman.o | CHDR_OBJS += $(CHDR)/src/libchdr_bitstream.o $(CHDR)/src/libchdr_huffman.o | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| # lzma
 | # lzma
 | ||||||
| LZMA = $(CHDR)/deps/lzma-19.00 | LZMA = $(CHDR)/deps/lzma-19.00 | ||||||
| LZMA_OBJS += $(LZMA)/src/CpuArch.o $(LZMA)/src/Alloc.o $(LZMA)/src/LzmaEnc.o | LZMA_OBJS += $(LZMA)/src/CpuArch.o $(LZMA)/src/Alloc.o $(LZMA)/src/LzmaEnc.o | ||||||
|  | @ -258,7 +262,7 @@ LZMA_OBJS += $(LZMA)/src/Sort.o $(LZMA)/src/LzmaDec.o $(LZMA)/src/LzFind.o | ||||||
| LZMA_OBJS += $(LZMA)/src/Delta.o | LZMA_OBJS += $(LZMA)/src/Delta.o | ||||||
| $(LZMA_OBJS): CFLAGS += -D_7ZIP_ST | $(LZMA_OBJS): CFLAGS += -D_7ZIP_ST | ||||||
| 
 | 
 | ||||||
| OBJS += $(CHDR_OBJS) $(FLAC_OBJS) $(LZMA_OBJS) | OBJS += $(CHDR_OBJS) $(LZMA_OBJS) | ||||||
| # ouf... prepend includes to overload headers available in the toolchain
 | # ouf... prepend includes to overload headers available in the toolchain
 | ||||||
| CHDR_I = $(shell find $(CHDR) -name 'include') | CHDR_I = $(shell find $(CHDR) -name 'include') | ||||||
| CFLAGS := $(patsubst %, -I%, $(CHDR_I)) $(CFLAGS) | CFLAGS := $(patsubst %, -I%, $(CHDR_I)) $(CFLAGS) | ||||||
|  | @ -297,7 +301,7 @@ target_: $(TARGET) | ||||||
| 
 | 
 | ||||||
| clean: | clean: | ||||||
| 	$(RM) $(TARGET) $(OBJS) pico/pico_int_offs.h | 	$(RM) $(TARGET) $(OBJS) pico/pico_int_offs.h | ||||||
| 	$(RM) -r .opk_data | 	$(RM) -r .od_data | ||||||
| 
 | 
 | ||||||
| $(TARGET): $(OBJS) | $(TARGET): $(OBJS) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 kub
						kub