mirror of
https://github.com/yann64/haikuports.git
synced 2026-05-06 06:58:57 +02:00
148 lines
4.1 KiB
Plaintext
148 lines
4.1 KiB
Plaintext
From 44d7e9a4ebb1062d5949f5a5d8e6346ad6cec8e9 Mon Sep 17 00:00:00 2001
|
|
From: Sergei Reznikov <diver@gelios.net>
|
|
Date: Tue, 5 Dec 2017 09:27:36 +0300
|
|
Subject: Fix build on Haiku
|
|
|
|
|
|
diff --git a/src/Add_Port_Window.cpp b/src/Add_Port_Window.cpp
|
|
index 116122c..9839aa8 100644
|
|
--- a/src/Add_Port_Window.cpp
|
|
+++ b/src/Add_Port_Window.cpp
|
|
@@ -32,6 +32,10 @@ Add_Port_Window::Add_Port_Window( QWidget *parent )
|
|
#ifdef Q_OS_UNIX
|
|
ui.RB_stdio->setEnabled( true );
|
|
#endif
|
|
+
|
|
+ #ifdef Q_OS_HAIKU
|
|
+ ui.RB_stdio->setEnabled( true );
|
|
+ #endif
|
|
|
|
#ifdef Q_OS_LINUX
|
|
ui.RB_pty->setEnabled( true );
|
|
diff --git a/src/System_Info.cpp b/src/System_Info.cpp
|
|
index fcbc984..5e368a5 100644
|
|
--- a/src/System_Info.cpp
|
|
+++ b/src/System_Info.cpp
|
|
@@ -2098,7 +2098,7 @@ bool System_Info::Delete_From_Used_USB_List( const VM_USB &device )
|
|
return Used_Host_USB.removeOne( device );
|
|
}
|
|
|
|
-#ifdef Q_OS_LINUX
|
|
+#if defined Q_OS_LINUX || defined Q_OS_HAIKU
|
|
|
|
bool System_Info::Update_Host_USB()
|
|
{
|
|
@@ -2503,7 +2503,7 @@ bool System_Info::Scan_USB_Proc( QList<VM_USB> &list )
|
|
return true;
|
|
}
|
|
|
|
-#include <sys/sysinfo.h>
|
|
+//#include <sys/sysinfo.h>
|
|
#include <QDir>
|
|
#include <QFileInfoList>
|
|
|
|
@@ -2595,12 +2595,12 @@ void System_Info::Get_Free_Memory_Size( int &allRAM, int &freeRAM )
|
|
}
|
|
|
|
// If proc fs not exists
|
|
- struct sysinfo sysInfo;
|
|
+/* struct sysinfo sysInfo;
|
|
sysinfo( &sysInfo );
|
|
|
|
allRAM = (int)(unsigned long)(sysInfo.totalram * sysInfo.mem_unit) / 1024.0 / 1024.0;
|
|
freeRAM = (int)(unsigned long)((sysInfo.freeram + sysInfo.bufferram) * sysInfo.mem_unit) / 1024.0 / 1024.0;
|
|
-}
|
|
+*/}
|
|
|
|
QStringList System_Info::Get_Host_FDD_List()
|
|
{
|
|
diff --git a/src/System_Info.h b/src/System_Info.h
|
|
index d0e2f35..fe325f7 100644
|
|
--- a/src/System_Info.h
|
|
+++ b/src/System_Info.h
|
|
@@ -59,7 +59,7 @@ class System_Info
|
|
static QMap<QString, Available_Devices> Emulator_QEMU_2_0;
|
|
|
|
private:
|
|
- #ifdef Q_OS_LINUX
|
|
+ #if defined Q_OS_LINUX || defined Q_OS_HAIKU
|
|
static bool Scan_USB_Sys( QList<VM_USB> &list );
|
|
static bool Scan_USB_Proc( QList<VM_USB> &list );
|
|
static bool Read_SysFS_File( const QString &path, QString &data );
|
|
diff --git a/src/main.cpp b/src/main.cpp
|
|
index 40a3c61..ace8799 100644
|
|
--- a/src/main.cpp
|
|
+++ b/src/main.cpp
|
|
@@ -240,7 +240,7 @@ int main( int argc, char *argv[] )
|
|
// Find Data Folder
|
|
if( settings.value("AQEMU_Data_Folder", "").toString().isEmpty() )
|
|
{
|
|
- #ifdef Q_OS_WIN32
|
|
+ #if defined Q_OS_WIN32 || defined Q_OS_HAIKU
|
|
if( QDir(QDir::currentPath() + "\\os_icons").exists() &&
|
|
QDir(QDir::currentPath() + "\\os_templates").exists() )
|
|
{
|
|
--
|
|
2.15.0
|
|
|
|
|
|
From 5ee1bb6c08ba39e6aeb494b14fe1601664ef752f Mon Sep 17 00:00:00 2001
|
|
From: Ho Tuan Kiet <tuankiet65@gmail.com>
|
|
Date: Sun, 24 Dec 2017 07:22:22 +0000
|
|
Subject: Fix total/free memory detection on Haiku
|
|
|
|
|
|
diff --git a/src/System_Info.cpp b/src/System_Info.cpp
|
|
index 5e368a5..6108df7 100644
|
|
--- a/src/System_Info.cpp
|
|
+++ b/src/System_Info.cpp
|
|
@@ -2595,12 +2595,23 @@ void System_Info::Get_Free_Memory_Size( int &allRAM, int &freeRAM )
|
|
}
|
|
|
|
// If proc fs not exists
|
|
-/* struct sysinfo sysInfo;
|
|
- sysinfo( &sysInfo );
|
|
-
|
|
- allRAM = (int)(unsigned long)(sysInfo.totalram * sysInfo.mem_unit) / 1024.0 / 1024.0;
|
|
- freeRAM = (int)(unsigned long)((sysInfo.freeram + sysInfo.bufferram) * sysInfo.mem_unit) / 1024.0 / 1024.0;
|
|
-*/}
|
|
+ #ifdef Q_OS_HAIKU
|
|
+ system_info sysinfo;
|
|
+ get_system_info(&sysinfo);
|
|
+
|
|
+ uint64 tmp;
|
|
+ tmp = (sysinfo.max_pages + sysinfo.ignored_pages) * B_PAGE_SIZE;
|
|
+ allRAM = (int)(tmp / 1024.0 / 1024.0);
|
|
+
|
|
+ freeRAM = (int)(sysinfo.free_memory / 1024.0 / 1024.0);
|
|
+ #else
|
|
+ struct sysinfo sysInfo;
|
|
+ sysinfo( &sysInfo );
|
|
+
|
|
+ allRAM = (int)(unsigned long)(sysInfo.totalram * sysInfo.mem_unit) / 1024.0 / 1024.0;
|
|
+ freeRAM = (int)(unsigned long)((sysInfo.freeram + sysInfo.bufferram) * sysInfo.mem_unit) / 1024.0 / 1024.0;
|
|
+ #endif
|
|
+}
|
|
|
|
QStringList System_Info::Get_Host_FDD_List()
|
|
{
|
|
diff --git a/src/System_Info.h b/src/System_Info.h
|
|
index fe325f7..64c0e41 100644
|
|
--- a/src/System_Info.h
|
|
+++ b/src/System_Info.h
|
|
@@ -26,6 +26,11 @@
|
|
#include "Utils.h"
|
|
#include "VM_Devices.h"
|
|
|
|
+#ifdef Q_OS_HAIKU
|
|
+// for memory size detection
|
|
+#include <OS.h>
|
|
+#endif
|
|
+
|
|
class System_Info
|
|
{
|
|
public:
|
|
--
|
|
2.15.0
|
|
|