aboutsummaryrefslogtreecommitdiff
path: root/examples/system/dynlink
diff options
context:
space:
mode:
authorJohn "Lameguy" Wilbert Villamor <lameguy64@gmail.com>2021-10-15 09:22:45 +0800
committerGitHub <noreply@github.com>2021-10-15 09:22:45 +0800
commitdd0f088aaa4c6bf013643be2d1d8621dbffdb000 (patch)
treed848d6ce007d8bb9357c8b99d6a0a39ec41d244e /examples/system/dynlink
parent9e08d1047fa8deeb3ccb3ce9bb11d69e25a52d56 (diff)
parenteb719a424e6a16fb64209139a32c9f8a7235a929 (diff)
downloadpsn00bsdk-dd0f088aaa4c6bf013643be2d1d8621dbffdb000.tar.gz
Merge pull request #38 from spicyjpeg/cmake
Full CMake support (in place of makefiles)
Diffstat (limited to 'examples/system/dynlink')
-rw-r--r--examples/system/dynlink/CMakeLists.txt32
-rw-r--r--examples/system/dynlink/iso.xml16
-rw-r--r--examples/system/dynlink/makefile95
3 files changed, 40 insertions, 103 deletions
diff --git a/examples/system/dynlink/CMakeLists.txt b/examples/system/dynlink/CMakeLists.txt
new file mode 100644
index 0000000..3af5d4b
--- /dev/null
+++ b/examples/system/dynlink/CMakeLists.txt
@@ -0,0 +1,32 @@
+# PSn00bSDK example CMake script
+# (C) 2021 spicyjpeg - MPL licensed
+
+cmake_minimum_required(VERSION 3.21)
+
+if(NOT DEFINED CMAKE_TOOLCHAIN_FILE AND DEFINED ENV{PSN00BSDK_LIBS})
+ set(CMAKE_TOOLCHAIN_FILE $ENV{PSN00BSDK_LIBS}/cmake/sdk.cmake)
+endif()
+
+project(
+ dynlink
+ LANGUAGES C
+ VERSION 1.0.0
+ DESCRIPTION "PSn00bSDK dynamic linker example"
+ HOMEPAGE_URL "http://lameguy64.net/?page=psn00bsdk"
+)
+
+file(GLOB _sources *.c)
+psn00bsdk_add_executable(dynlink_main DYNAMIC ${_sources})
+psn00bsdk_add_library (dynlink_cube SHARED library/cube.c)
+psn00bsdk_add_library (dynlink_balls SHARED library/balls.c)
+psn00bsdk_add_cd_image(
+ dynlink_iso dynlink iso.xml
+ DEPENDS dynlink_main dynlink_cube dynlink_balls
+)
+
+install(
+ FILES
+ ${PROJECT_BINARY_DIR}/dynlink.bin
+ ${PROJECT_BINARY_DIR}/dynlink.cue
+ DESTINATION .
+)
diff --git a/examples/system/dynlink/iso.xml b/examples/system/dynlink/iso.xml
index 76cc8fc..8f40510 100644
--- a/examples/system/dynlink/iso.xml
+++ b/examples/system/dynlink/iso.xml
@@ -1,7 +1,7 @@
<?xml version="1.0" encoding="utf-8"?>
<iso_project
- image_name="build/dynlink.bin"
- cue_sheet="build/dynlink.cue"
+ image_name="${CD_IMAGE_NAME}.bin"
+ cue_sheet="${CD_IMAGE_NAME}.cue"
>
<track type="data">
<identifiers
@@ -9,18 +9,18 @@
volume ="DYNLINK"
volume_set ="DYNLINK"
publisher ="MEIDOTEK"
- data_preparer ="PSN00BSDK BUILD SCRIPT"
+ data_preparer ="PSN00BSDK ${PSN00BSDK_VERSION}"
application ="PLAYSTATION"
copyright ="README.TXT;1"
/>
<directory_tree>
- <file name="SYSTEM.CNF" type="data" source="system.cnf" />
- <file name="MAIN.EXE" type="data" source="build/main.exe" />
- <file name="MAIN.MAP" type="data" source="build/main.map" />
+ <file name="SYSTEM.CNF" type="data" source="${PROJECT_SOURCE_DIR}/system.cnf" />
+ <file name="MAIN.EXE" type="data" source="dynlink_main.exe" />
+ <file name="MAIN.MAP" type="data" source="dynlink_main.map" />
- <file name="CUBE.DLL" type="data" source="build/library/cube.dll" />
- <file name="BALLS.DLL" type="data" source="build/library/balls.dll" />
+ <file name="CUBE.DLL" type="data" source="dynlink_cube.dll" />
+ <file name="BALLS.DLL" type="data" source="dynlink_balls.dll" />
<dummy sectors="1024"/>
</directory_tree>
diff --git a/examples/system/dynlink/makefile b/examples/system/dynlink/makefile
deleted file mode 100644
index b3fb298..0000000
--- a/examples/system/dynlink/makefile
+++ /dev/null
@@ -1,95 +0,0 @@
-# PSn00bSDK makefile template
-# Part of the PSn00bSDK Project
-# 2019 - 2021 Lameguy64 / Meido-Tek Productions
-
-## Settings
-
-PSN00BSDK_LIBS ?= ../../../libpsn00b
-
-# Edit this to point to psn00bsdk-setup.mk, or copy that over to your project's
-# root folder (it only depends on environment variables).
-include ../../../psn00bsdk-setup.mk
-
-# Project target name
-#TARGET = dynlink
-
-## Files
-
-# Searches for C, C++ and S (assembler) files in local directory
-CFILES_MAIN = $(notdir $(wildcard *.c))
-CPPFILES_MAIN = $(notdir $(wildcard *.cpp))
-AFILES_MAIN = $(notdir $(wildcard *.s))
-
-CFILES_DLL = $(notdir $(wildcard library/*.c))
-CPPFILES_DLL = $(notdir $(wildcard library/*.cpp))
-AFILES_DLL = $(notdir $(wildcard library/*.s))
-
-# Create names for object files
-OFILES_MAIN = $(addprefix build/,$(CFILES_MAIN:.c=.o)) \
- $(addprefix build/,$(CPPFILES_MAIN:.cpp=.o)) \
- $(addprefix build/,$(AFILES_MAIN:.s=.o))
-OFILES_CUBE = build/library/cube.o
-OFILES_BALLS = build/library/balls.o
-
-# Project specific includes and libraries
-# (use -I for include dirs, -L for library dirs, -l for static libraries)
-INCLUDE +=
-LIBDIRS +=
-LIBS +=
-
-## Build rules
-
-all: iso
-#all: build/library/cube build/library/balls build/main
-
-iso: build/library/cube build/library/balls build/main resources
- $(MKPSXISO) -y -q iso.xml
-
-resources:
- # Add commands to build/convert your assets here
- #$(LZPACK) data.xml
-
-build/library/cube: $(OFILES_CUBE)
- @mkdir -p $(dir $@)
- $(LD) $(LDFLAGS_DLL) $^ -o $@
- #$(NM) -f posix -l -n $@ >$@.map
- $(OBJCOPY) -O binary $@ $@.dll
-
-build/library/balls: $(OFILES_BALLS)
- @mkdir -p $(dir $@)
- $(LD) $(LDFLAGS_DLL) $^ -o $@
- #$(NM) -f posix -l -n $@ >$@.map
- $(OBJCOPY) -O binary $@ $@.dll
-
-build/main: $(OFILES_MAIN)
- @mkdir -p $(dir $@)
- $(LD) $(LDFLAGS_EXEDYN) $(LIBDIRS) $^ $(LIBS) -o $@
- $(NM) -f posix -l -n $@ >$@.map
- $(ELF2X) -q $@ $@.exe
-
-build/library/%.o: library/%.c
- @mkdir -p $(dir $@)
- $(CC) $(CFLAGS_DLL) $(INCLUDE) -c $< -o $@
-
-build/library/%.o: library/%.cpp
- @mkdir -p $(dir $@)
- $(CXX) $(CPPFLAGS_DLL) $(INCLUDE) -c $< -o $@
-
-build/library/%.o: library/%.s
- @mkdir -p $(dir $@)
- $(CC) $(AFLAGS_DLL) $(INCLUDE) -c $< -o $@
-
-build/%.o: %.c
- @mkdir -p $(dir $@)
- $(CC) $(CFLAGS_EXEDYN) $(INCLUDE) -c $< -o $@
-
-build/%.o: %.cpp
- @mkdir -p $(dir $@)
- $(CXX) $(CPPFLAGS_EXEDYN) $(INCLUDE) -c $< -o $@
-
-build/%.o: %.s
- @mkdir -p $(dir $@)
- $(CC) $(AFLAGS_EXEDYN) $(INCLUDE) -c $< -o $@
-
-clean:
- rm -rf build