Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for building on ARM64 MacOS #854

Open
wants to merge 12 commits into
base: develop/2.4.0
Choose a base branch
from
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2152,3 +2152,4 @@ lib/libs2d_engine.a

# user-specific config file
include/config/config_local.h
.DS_Store
34 changes: 24 additions & 10 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -468,16 +468,19 @@ else ifeq ($(COMPILER),clang)
CC := clang
CXX := clang++
endif
# Prefer gcc's cpp if installed on the system
ifneq (,$(call find-command,cpp-10))
CPP := cpp-10
else
CPP := cpp
endif
ifneq ($(call find-command,mips-n64-ld),)
LD := mips-n64-ld

OS := $(shell uname)
ARCH := $(shell uname -p)

# Check if we're running MacOS, then check processor architecture.
gheskett marked this conversation as resolved.
Show resolved Hide resolved
ifeq ($(ARCH), arm)
LD := tools/mips64-elf-ld-arm
else
LD := tools/mips64-elf-ld
ifneq ($(call find-command,mips-n64-ld),)
LD := mips-n64-ld
else
LD := tools/mips64-elf-ld
endif
endif
AR := $(CROSS)ar
OBJDUMP := $(CROSS)objdump
Expand All @@ -503,6 +506,18 @@ endif
C_DEFINES := $(foreach d,$(DEFINES),-D$(d))
DEF_INC_CFLAGS := $(foreach i,$(INCLUDE_DIRS),-I$(i)) $(C_DEFINES)

# Prefer gcc's cpp if installed on the system
ifneq (,$(call find-command,clang))
CPP := clang
CPPFLAGS := -E -P -x c -Wno-trigraphs $(DEF_INC_CFLAGS)
else ifneq (,$(call find-command,cpp-10))
CPP := cpp-10
CPPFLAGS := -P -Wno-trigraphs $(DEF_INC_CFLAGS)
else
CPP := cpp
CPPFLAGS := -P -Wno-trigraphs $(DEF_INC_CFLAGS)
endif

# C compiler options
CFLAGS = -G 0 $(OPT_FLAGS) $(TARGET_CFLAGS) $(MIPSISET) $(DEF_INC_CFLAGS)
ifeq ($(COMPILER),gcc)
Expand All @@ -520,7 +535,6 @@ ASFLAGS := -march=vr4300 -mabi=32 $(foreach i,$(INCLUDE_DIRS),-I$(i)) $(fore
RSPASMFLAGS := $(foreach d,$(DEFINES),-definelabel $(subst =, ,$(d)))

# C preprocessor flags
CPPFLAGS := -P -Wno-trigraphs $(DEF_INC_CFLAGS)

#==============================================================================#
# Miscellaneous Tools #
Expand Down
4 changes: 2 additions & 2 deletions sm64.ld
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@ OUTPUT_ARCH (mips)

#define LINKER /* Removes externs from preprocessed script */
#define TARGET_N64
#include "segments.h"
#include "config.h"
#include "include/segments.h"
#include "include/config.h"
#undef LINKER

#define BEGIN_SEG(name, addr) \
Expand Down
8 changes: 7 additions & 1 deletion tools/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,15 @@ CC := gcc
CXX := g++
CFLAGS := -I. -O2 -s
LDFLAGS := -lm
ALL_PROGRAMS := armips filesizer rncpack n64graphics n64graphics_ci mio0 slienc n64cksum textconv aifc_decode aiff_extract_codebook vadpcm_enc tabledesign extract_data_for_mio skyconv flips
ALL_PROGRAMS := armips filesizer rncpack n64graphics n64graphics_ci mio0 slienc n64cksum textconv aifc_decode aiff_extract_codebook vadpcm_enc tabledesign extract_data_for_mio skyconv
LIBAUDIOFILE := audiofile/libaudiofile.a

OS := $(shell uname)

ifneq ($(OS), Darwin)
ALL_PROGRAMS += flips
endif

ifeq ($(OS),Windows_NT)
EXT := .exe
OUTPUTS := $(ALL_PROGRAMS:=.exe)
Expand Down
2 changes: 1 addition & 1 deletion tools/filesizer.c
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#ifndef _WIN32
#if !defined(_WIN32) && !defined(__APPLE__)
#include <byteswap.h>
#else
#define __bswap_constant_32(x) \
Expand Down
Binary file added tools/mips64-elf-ld-arm
Binary file not shown.