Ports: Update openttd's patches to use git patches

This commit is contained in:
Ali Mohammad Pur 2022-05-16 22:55:50 +04:30 committed by Ali Mohammad Pur
parent 2c71a62e09
commit 32c380b7f9
11 changed files with 201 additions and 78 deletions

View file

@ -1,7 +1,22 @@
diff -Naur openttd-1.11.0/cmake/CompileFlags.cmake openttd-1.11.0.serenity/cmake/CompileFlags.cmake
--- openttd-1.11.0/cmake/CompileFlags.cmake 2021-04-01 14:33:44.000000000 +0200
+++ openttd-1.11.0.serenity/cmake/CompileFlags.cmake 2021-04-19 19:30:33.457232215 +0200
@@ -158,7 +158,7 @@
From e7cb850da0851c27197f39a2a6593c1c80981a6c Mon Sep 17 00:00:00 2001
From: Gunnar Beutner <gbeutner@serenityos.org>
Date: Tue, 5 Apr 2022 23:05:14 +0200
Subject: [PATCH 1/6] All sorts of fixes for the build
Co-Authored-By: Kevin Nobel <kevin@2sk.nl>
---
cmake/CompileFlags.cmake | 2 +-
src/network/core/host.cpp | 2 ++
src/network/core/os_abstraction.h | 3 ++-
src/os/unix/unix.cpp | 4 +++-
src/stdafx.h | 6 +++---
5 files changed, 11 insertions(+), 6 deletions(-)
diff --git a/cmake/CompileFlags.cmake b/cmake/CompileFlags.cmake
index ad4a46a..50df38e 100644
--- a/cmake/CompileFlags.cmake
+++ b/cmake/CompileFlags.cmake
@@ -163,7 +163,7 @@ macro(compile_flags)
message(FATAL_ERROR "No warning flags are set for this compiler yet; please consider creating a Pull Request to add support for this compiler.")
endif()
@ -10,10 +25,11 @@ diff -Naur openttd-1.11.0/cmake/CompileFlags.cmake openttd-1.11.0.serenity/cmake
# rdynamic is used to get useful stack traces from crash reports.
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -rdynamic")
endif()
diff -Naur openttd-1.11.0/src/network/core/host.cpp openttd-1.11.0.serenity/src/network/core/host.cpp
--- openttd-1.11.0/src/network/core/host.cpp 2021-04-01 14:33:44.000000000 +0200
+++ openttd-1.11.0.serenity/src/network/core/host.cpp 2021-04-19 19:30:33.457232215 +0200
@@ -147,6 +147,7 @@
diff --git a/src/network/core/host.cpp b/src/network/core/host.cpp
index b55f5f5..0ae76d3 100644
--- a/src/network/core/host.cpp
+++ b/src/network/core/host.cpp
@@ -82,6 +82,7 @@ static void NetworkFindBroadcastIPsInternal(NetworkAddressList *broadcast) // Wi
static void NetworkFindBroadcastIPsInternal(NetworkAddressList *broadcast) // !GETIFADDRS implementation
{
@ -21,7 +37,7 @@ diff -Naur openttd-1.11.0/src/network/core/host.cpp openttd-1.11.0.serenity/src/
SOCKET sock = socket(AF_INET, SOCK_DGRAM, 0);
if (sock == INVALID_SOCKET) return;
@@ -183,6 +184,7 @@
@@ -118,6 +119,7 @@ static void NetworkFindBroadcastIPsInternal(NetworkAddressList *broadcast) // !G
}
closesocket(sock);
@ -29,10 +45,11 @@ diff -Naur openttd-1.11.0/src/network/core/host.cpp openttd-1.11.0.serenity/src/
}
#endif /* all NetworkFindBroadcastIPsInternals */
diff -Naur openttd-1.11.0/src/network/core/os_abstraction.h openttd-1.11.0.serenity/src/network/core/os_abstraction.h
--- openttd-1.11.0/src/network/core/os_abstraction.h 2021-04-01 14:33:44.000000000 +0200
+++ openttd-1.11.0.serenity/src/network/core/os_abstraction.h 2021-04-19 19:30:33.457232215 +0200
@@ -59,13 +59,14 @@
diff --git a/src/network/core/os_abstraction.h b/src/network/core/os_abstraction.h
index 6bb6101..100678a 100644
--- a/src/network/core/os_abstraction.h
+++ b/src/network/core/os_abstraction.h
@@ -74,13 +74,14 @@ typedef unsigned long in_addr_t;
# include <unistd.h>
# include <sys/ioctl.h>
# include <sys/socket.h>
@ -48,9 +65,10 @@ diff -Naur openttd-1.11.0/src/network/core/os_abstraction.h openttd-1.11.0.seren
/* If for any reason ifaddrs.h does not exist on your system, comment out
* the following two lines and an alternative way will be used to fetch
* the list of IPs from the system. */
diff -Naur openttd-1.11.0/src/os/unix/unix.cpp openttd-1.11.0.serenity/src/os/unix/unix.cpp
--- openttd-1.11.0/src/os/unix/unix.cpp 2021-04-01 14:33:44.000000000 +0200
+++ openttd-1.11.0.serenity/src/os/unix/unix.cpp 2021-04-19 19:30:33.457232215 +0200
diff --git a/src/os/unix/unix.cpp b/src/os/unix/unix.cpp
index 95d6fa1..3c7b567 100644
--- a/src/os/unix/unix.cpp
+++ b/src/os/unix/unix.cpp
@@ -42,9 +42,11 @@
# define HAS_SYSCTL
#endif
@ -63,7 +81,7 @@ diff -Naur openttd-1.11.0/src/os/unix/unix.cpp openttd-1.11.0.serenity/src/os/un
#ifdef HAS_SYSCTL
#include <sys/sysctl.h>
@@ -84,7 +86,7 @@
@@ -84,7 +86,7 @@ bool FiosGetDiskFreeSpace(const char *path, uint64 *tot)
if (statfs(path, &s) != 0) return false;
free = (uint64)s.f_bsize * s.f_bavail;
@ -72,10 +90,11 @@ diff -Naur openttd-1.11.0/src/os/unix/unix.cpp openttd-1.11.0.serenity/src/os/un
struct statvfs s;
if (statvfs(path, &s) != 0) return false;
diff -Naur openttd-1.11.0/src/stdafx.h openttd-1.11.0.serenity/src/stdafx.h
--- openttd-1.11.0/src/stdafx.h 2021-04-01 14:33:44.000000000 +0200
+++ openttd-1.11.0.serenity/src/stdafx.h 2021-04-19 20:08:30.758187723 +0200
@@ -28,7 +28,7 @@
diff --git a/src/stdafx.h b/src/stdafx.h
index effd57c..98800f9 100644
--- a/src/stdafx.h
+++ b/src/stdafx.h
@@ -38,7 +38,7 @@
# define TROUBLED_INTS
#endif
@ -84,7 +103,7 @@ diff -Naur openttd-1.11.0/src/stdafx.h openttd-1.11.0.serenity/src/stdafx.h
# include <strings.h> /* strncasecmp */
#endif
@@ -107,7 +107,7 @@
@@ -118,7 +118,7 @@
# define strcasecmp stricmp
#endif
@ -93,7 +112,7 @@ diff -Naur openttd-1.11.0/src/stdafx.h openttd-1.11.0.serenity/src/stdafx.h
# include <alloca.h>
#endif
@@ -307,7 +307,7 @@
@@ -318,7 +318,7 @@
typedef unsigned char byte;
/* This is already defined in unix, but not in QNX Neutrino (6.x) or Cygwin. */
@ -102,3 +121,6 @@ diff -Naur openttd-1.11.0/src/stdafx.h openttd-1.11.0.serenity/src/stdafx.h
typedef unsigned int uint;
#endif
--
2.36.1

View file

@ -1,7 +1,18 @@
diff -Naur openttd-1.11.0/src/spritecache.cpp openttd-1.11.0.serenity/src/spritecache.cpp
--- openttd-1.11.0/src/spritecache.cpp 2021-04-01 14:33:44.000000000 +0200
+++ openttd-1.11.0.serenity/src/spritecache.cpp 2021-04-18 21:03:15.916430052 +0200
@@ -915,6 +915,7 @@
From 1e9569da4e5b1855031495ca2455ed6fa186b3df Mon Sep 17 00:00:00 2001
From: Gunnar Beutner <gbeutner@serenityos.org>
Date: Sat, 17 Apr 2021 15:40:17 +0200
Subject: [PATCH 2/6] Memory
FIXME: There is no information available about this patch, fill this in.
---
src/spritecache.cpp | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/src/spritecache.cpp b/src/spritecache.cpp
index 6d5ce01..2fda8df 100644
--- a/src/spritecache.cpp
+++ b/src/spritecache.cpp
@@ -944,6 +944,7 @@ static void GfxInitSpriteCache()
/* Remember 'target_size' from the previous allocation attempt, so we do not try to reach the target_size multiple times in case of failure. */
static uint last_alloc_attempt = 0;
@ -9,7 +20,7 @@ diff -Naur openttd-1.11.0/src/spritecache.cpp openttd-1.11.0.serenity/src/sprite
if (_spritecache_ptr == nullptr || (_allocated_sprite_cache_size != target_size && target_size != last_alloc_attempt)) {
delete[] reinterpret_cast<byte *>(_spritecache_ptr);
@@ -950,6 +951,10 @@
@@ -979,6 +980,10 @@ static void GfxInitSpriteCache()
ScheduleErrorMessage(msg);
}
}
@ -20,3 +31,6 @@ diff -Naur openttd-1.11.0/src/spritecache.cpp openttd-1.11.0.serenity/src/sprite
/* A big free block */
_spritecache_ptr->size = (_allocated_sprite_cache_size - sizeof(MemBlock)) | S_FREE_MASK;
--
2.36.1

View file

@ -0,0 +1,25 @@
From 4e0667f3f744b6e7a8ad73581747122d617ea069 Mon Sep 17 00:00:00 2001
From: Kevin Nobel <kevin@2sk.nl>
Date: Tue, 5 Apr 2022 23:05:14 +0200
Subject: [PATCH 3/6] Pass `setsockopt` argument as char*
---
src/network/core/os_abstraction.cpp | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/network/core/os_abstraction.cpp b/src/network/core/os_abstraction.cpp
index 225c95d..2da1575 100644
--- a/src/network/core/os_abstraction.cpp
+++ b/src/network/core/os_abstraction.cpp
@@ -172,7 +172,7 @@ bool SetReusePort(SOCKET d)
return setsockopt(d, SOL_SOCKET, SO_REUSEADDR, (const char *)&reuse_port, sizeof(reuse_port)) == 0;
#else
int reuse_port = 1;
- return setsockopt(d, SOL_SOCKET, SO_REUSEPORT, &reuse_port, sizeof(reuse_port)) == 0;
+ return setsockopt(d, SOL_SOCKET, SO_REUSEADDR, (const char *)&reuse_port, sizeof(reuse_port)) == 0;
#endif
}
--
2.36.1

View file

@ -0,0 +1,28 @@
From 4a6442ab29becbd29418161635930a4d6d5d55e2 Mon Sep 17 00:00:00 2001
From: Gunnar Beutner <gbeutner@serenityos.org>
Date: Thu, 29 Apr 2021 23:45:51 +0200
Subject: [PATCH 4/6] Stub GetPerformanceTimer() to return 0
---
src/framerate_gui.cpp | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/src/framerate_gui.cpp b/src/framerate_gui.cpp
index 1077629..2d15c5b 100644
--- a/src/framerate_gui.cpp
+++ b/src/framerate_gui.cpp
@@ -222,8 +222,9 @@ namespace {
*/
static TimingMeasurement GetPerformanceTimer()
{
- using namespace std::chrono;
- return (TimingMeasurement)time_point_cast<microseconds>(high_resolution_clock::now()).time_since_epoch().count();
+ //using namespace std::chrono;
+ //return (TimingMeasurement)time_point_cast<microseconds>(high_resolution_clock::now()).time_since_epoch().count();
+ return 0;
}
--
2.36.1

View file

@ -0,0 +1,25 @@
From 4cf117000029c0620085bd273776dc704e6ebc91 Mon Sep 17 00:00:00 2001
From: Gunnar Beutner <gbeutner@serenityos.org>
Date: Sat, 17 Apr 2021 15:40:17 +0200
Subject: [PATCH 5/6] Don't use the asm version of rdtsc
---
src/cpu.cpp | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/cpu.cpp b/src/cpu.cpp
index d95c704..762da79 100644
--- a/src/cpu.cpp
+++ b/src/cpu.cpp
@@ -40,7 +40,7 @@ unsigned __int64 ottd_rdtsc();
#endif
/* rdtsc for all other *nix-en (hopefully). Use GCC syntax */
-#if (defined(__i386__) || defined(__x86_64__)) && !defined(RDTSC_AVAILABLE)
+#if (defined(__i386__) || defined(__x86_64__)) && !defined(__serenity__) && !defined(RDTSC_AVAILABLE)
uint64 ottd_rdtsc()
{
uint32 high, low;
--
2.36.1

View file

@ -0,0 +1,25 @@
From 42d2fd4d5ab2aa8883f3722c9008e7413980a755 Mon Sep 17 00:00:00 2001
From: Gunnar Beutner <gbeutner@serenityos.org>
Date: Sat, 17 Apr 2021 15:40:17 +0200
Subject: [PATCH 6/6] Don't set any signal handlers
---
src/os/unix/crashlog_unix.cpp | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/os/unix/crashlog_unix.cpp b/src/os/unix/crashlog_unix.cpp
index fc3682d..32b5f1e 100644
--- a/src/os/unix/crashlog_unix.cpp
+++ b/src/os/unix/crashlog_unix.cpp
@@ -178,7 +178,7 @@ static void CDECL HandleCrash(int signum)
/* static */ void CrashLog::InitialiseCrashLog()
{
for (const int *i = _signals_to_handle; i != endof(_signals_to_handle); i++) {
- signal(*i, HandleCrash);
+ //signal(*i, HandleCrash);
}
}
--
2.36.1

View file

@ -0,0 +1,34 @@
# Patches for openttd on SerenityOS
## `0001-All-sorts-of-fixes-for-the-build.patch`
All sorts of fixes for the build
## `0002-Memory.patch`
Memory
FIXME: There is no information available about this patch, fill this in.
## `0003-Pass-setsockopt-argument-as-char.patch`
Pass `setsockopt` argument as char*
## `0004-Stub-GetPerformanceTimer-to-return-0.patch`
Stub GetPerformanceTimer() to return 0
## `0005-Don-t-use-the-asm-version-of-rdtsc.patch`
Don't use the asm version of rdtsc
## `0006-Don-t-set-any-signal-handlers.patch`
Don't set any signal handlers

View file

@ -1,11 +0,0 @@
--- openttd-12.1/src/network/core/os_abstraction_original.cpp 2022-03-31 15:13:24.270873422 +0200
+++ openttd-12.1/src/network/core/os_abstraction.cpp 2022-03-31 15:14:01.978511406 +0200
@@ -172,7 +172,7 @@
return setsockopt(d, SOL_SOCKET, SO_REUSEADDR, (const char *)&reuse_port, sizeof(reuse_port)) == 0;
#else
int reuse_port = 1;
- return setsockopt(d, SOL_SOCKET, SO_REUSEPORT, &reuse_port, sizeof(reuse_port)) == 0;
+ return setsockopt(d, SOL_SOCKET, SO_REUSEADDR, (const char *)&reuse_port, sizeof(reuse_port)) == 0;
#endif
}

View file

@ -1,15 +0,0 @@
diff -Naur openttd-1.11.0/src/framerate_gui.cpp openttd-1.11.0.serenity/src/framerate_gui.cpp
--- openttd-1.11.0/src/framerate_gui.cpp 2021-04-29 23:45:25.247427868 +0200
+++ openttd-1.11.0.serenity/src/framerate_gui.cpp 2021-04-29 23:41:57.679926623 +0200
@@ -222,8 +222,9 @@
*/
static TimingMeasurement GetPerformanceTimer()
{
- using namespace std::chrono;
- return (TimingMeasurement)time_point_cast<microseconds>(high_resolution_clock::now()).time_since_epoch().count();
+ //using namespace std::chrono;
+ //return (TimingMeasurement)time_point_cast<microseconds>(high_resolution_clock::now()).time_since_epoch().count();
+ return 0;
}

View file

@ -1,12 +0,0 @@
diff -Naur openttd-1.11.0/src/cpu.cpp openttd-1.11.0.serenity/src/cpu.cpp
--- openttd-1.11.0/src/cpu.cpp 2021-04-22 01:14:21.038920133 +0200
+++ openttd-1.11.0.serenity/src/cpu.cpp 2021-04-22 01:13:56.638440518 +0200
@@ -40,7 +40,7 @@
#endif
/* rdtsc for all other *nix-en (hopefully). Use GCC syntax */
-#if (defined(__i386__) || defined(__x86_64__)) && !defined(RDTSC_AVAILABLE)
+#if (defined(__i386__) || defined(__x86_64__)) && !defined(__serenity__) && !defined(RDTSC_AVAILABLE)
uint64 ottd_rdtsc()
{
uint32 high, low;

View file

@ -1,12 +0,0 @@
diff -Naur openttd-1.11.0/src/os/unix/crashlog_unix.cpp openttd-1.11.0.serenity/src/os/unix/crashlog_unix.cpp
--- openttd-1.11.0/src/os/unix/crashlog_unix.cpp 2021-04-01 14:33:44.000000000 +0200
+++ openttd-1.11.0.serenity/src/os/unix/crashlog_unix.cpp 2021-04-18 21:40:06.426298674 +0200
@@ -178,7 +178,7 @@
/* static */ void CrashLog::InitialiseCrashLog()
{
for (const int *i = _signals_to_handle; i != endof(_signals_to_handle); i++) {
- signal(*i, HandleCrash);
+ //signal(*i, HandleCrash);
}
}