summaryrefslogtreecommitdiff
path: root/source/3rd-party/SDL2/src/power/haiku/SDL_syspower.c
diff options
context:
space:
mode:
Diffstat (limited to 'source/3rd-party/SDL2/src/power/haiku/SDL_syspower.c')
-rw-r--r--source/3rd-party/SDL2/src/power/haiku/SDL_syspower.c128
1 files changed, 128 insertions, 0 deletions
diff --git a/source/3rd-party/SDL2/src/power/haiku/SDL_syspower.c b/source/3rd-party/SDL2/src/power/haiku/SDL_syspower.c
new file mode 100644
index 0000000..47961bb
--- /dev/null
+++ b/source/3rd-party/SDL2/src/power/haiku/SDL_syspower.c
@@ -0,0 +1,128 @@
+/*
+ Simple DirectMedia Layer
+ Copyright (C) 1997-2018 Sam Lantinga <slouken@libsdl.org>
+
+ This software is provided 'as-is', without any express or implied
+ warranty. In no event will the authors be held liable for any damages
+ arising from the use of this software.
+
+ Permission is granted to anyone to use this software for any purpose,
+ including commercial applications, and to alter it and redistribute it
+ freely, subject to the following restrictions:
+
+ 1. The origin of this software must not be misrepresented; you must not
+ claim that you wrote the original software. If you use this software
+ in a product, an acknowledgment in the product documentation would be
+ appreciated but is not required.
+ 2. Altered source versions must be plainly marked as such, and must not be
+ misrepresented as being the original software.
+ 3. This notice may not be removed or altered from any source distribution.
+*/
+#include "../../SDL_internal.h"
+
+/* uses BeOS euc.jp apm driver. */
+/* !!! FIXME: does this thing even work on Haiku? */
+
+#ifndef SDL_POWER_DISABLED
+#if SDL_POWER_HAIKU
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <fcntl.h>
+#include <ctype.h>
+#include <drivers/Drivers.h>
+
+/* These values are from apm.h ... */
+#define APM_DEVICE_PATH "/dev/misc/apm"
+#define APM_FUNC_OFFSET 0x5300
+#define APM_FUNC_GET_POWER_STATUS 10
+#define APM_DEVICE_ALL 1
+#define APM_BIOS_CALL (B_DEVICE_OP_CODES_END + 3)
+
+#include "SDL_power.h"
+
+SDL_bool
+SDL_GetPowerInfo_Haiku(SDL_PowerState * state, int *seconds, int *percent)
+{
+ const int fd = open("/dev/misc/apm", O_RDONLY);
+ SDL_bool need_details = SDL_FALSE;
+ uint16 regs[6];
+ uint8 ac_status;
+ uint8 battery_status;
+ uint8 battery_flags;
+ uint8 battery_life;
+ uint32 battery_time;
+ int rc;
+
+ if (fd == -1) {
+ return SDL_FALSE; /* maybe some other method will work? */
+ }
+
+ memset(regs, '\0', sizeof(regs));
+ regs[0] = APM_FUNC_OFFSET + APM_FUNC_GET_POWER_STATUS;
+ regs[1] = APM_DEVICE_ALL;
+ rc = ioctl(fd, APM_BIOS_CALL, regs);
+ close(fd);
+
+ if (rc < 0) {
+ return SDL_FALSE;
+ }
+
+ ac_status = regs[1] >> 8;
+ battery_status = regs[1] & 0xFF;
+ battery_flags = regs[2] >> 8;
+ battery_life = regs[2] & 0xFF;
+ battery_time = (uint32) regs[3];
+
+ /* in theory, _something_ should be set in battery_flags, right? */
+ if (battery_flags == 0x00) { /* older APM BIOS? Less fields. */
+ battery_time = 0xFFFF;
+ if (battery_status == 0xFF) {
+ battery_flags = 0xFF;
+ } else {
+ battery_flags = (1 << battery_status);
+ }
+ }
+
+ if ((battery_time != 0xFFFF) && (battery_time & (1 << 15))) {
+ /* time is in minutes, not seconds */
+ battery_time = (battery_time & 0x7FFF) * 60;
+ }
+
+ if (battery_flags == 0xFF) { /* unknown state */
+ *state = SDL_POWERSTATE_UNKNOWN;
+ } else if (battery_flags & (1 << 7)) { /* no battery */
+ *state = SDL_POWERSTATE_NO_BATTERY;
+ } else if (battery_flags & (1 << 3)) { /* charging */
+ *state = SDL_POWERSTATE_CHARGING;
+ need_details = SDL_TRUE;
+ } else if (ac_status == 1) {
+ *state = SDL_POWERSTATE_CHARGED; /* on AC, not charging. */
+ need_details = SDL_TRUE;
+ } else {
+ *state = SDL_POWERSTATE_ON_BATTERY; /* not on AC. */
+ need_details = SDL_TRUE;
+ }
+
+ *percent = -1;
+ *seconds = -1;
+ if (need_details) {
+ const int pct = (int) battery_life;
+ const int secs = (int) battery_time;
+
+ if (pct != 255) { /* 255 == unknown */
+ *percent = (pct > 100) ? 100 : pct; /* clamp between 0%, 100% */
+ }
+ if (secs != 0xFFFF) { /* 0xFFFF == unknown */
+ *seconds = secs;
+ }
+ }
+
+ return SDL_TRUE; /* the definitive answer if APM driver replied. */
+}
+
+#endif /* SDL_POWER_HAIKU */
+#endif /* SDL_POWER_DISABLED */
+
+/* vi: set ts=4 sw=4 expandtab: */