diff options
author | marcus <marcus@df743ca5-7f9a-e211-a948-0013205c9059> | 2005-02-14 09:45:28 +0800 |
---|---|---|
committer | marcus <marcus@df743ca5-7f9a-e211-a948-0013205c9059> | 2005-02-14 09:45:28 +0800 |
commit | 15366306a0eb6be860cd219fb15656c006e28d52 (patch) | |
tree | 8b03a1db83b74fbe423b878c5a6487690d3e6dd9 | |
parent | 5c5d5736e6677aff43dfb130613cf0863165267e (diff) | |
download | marcuscom-ports-15366306a0eb6be860cd219fb15656c006e28d52.tar marcuscom-ports-15366306a0eb6be860cd219fb15656c006e28d52.tar.gz marcuscom-ports-15366306a0eb6be860cd219fb15656c006e28d52.tar.bz2 marcuscom-ports-15366306a0eb6be860cd219fb15656c006e28d52.tar.lz marcuscom-ports-15366306a0eb6be860cd219fb15656c006e28d52.tar.xz marcuscom-ports-15366306a0eb6be860cd219fb15656c006e28d52.tar.zst marcuscom-ports-15366306a0eb6be860cd219fb15656c006e28d52.zip |
Another battstat fix to reduce CPU usage by not actually installing the
a timeout handler recursively. I'm holding off on the PORTREVISION bump as
I have more cpufreq changes in the works.
Tested by: sajd on #freebsd-gnome
git-svn-id: svn://creme-brulee.marcuscom.com/ports/trunk@3649 df743ca5-7f9a-e211-a948-0013205c9059
-rw-r--r-- | x11/gnome-applets/files/patch-battstat-acpi | 33 | ||||
-rw-r--r-- | x11/gnomeapplets2/files/patch-battstat-acpi | 33 |
2 files changed, 20 insertions, 46 deletions
diff --git a/x11/gnome-applets/files/patch-battstat-acpi b/x11/gnome-applets/files/patch-battstat-acpi index 7c8e5d413..38aa935c1 100644 --- a/x11/gnome-applets/files/patch-battstat-acpi +++ b/x11/gnome-applets/files/patch-battstat-acpi @@ -66,7 +66,7 @@ + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Street #330, Boston, MA 02111-1307, USA. + * -+ $Id: patch-battstat-acpi,v 1.8 2005-02-13 06:46:10 marcus Exp $ ++ $Id: patch-battstat-acpi,v 1.9 2005-02-14 01:45:28 marcus Exp $ + */ + +/* @@ -322,8 +322,8 @@ }; --- battstat/power-management.c.orig Thu Jan 13 23:06:40 2005 -+++ battstat/power-management.c Sun Feb 13 01:42:21 2005 -@@ -76,6 +76,24 @@ ++++ battstat/power-management.c Sun Feb 13 20:44:23 2005 +@@ -76,6 +76,14 @@ #ifdef __FreeBSD__ #include <machine/apm_bios.h> @@ -332,23 +332,13 @@ +struct acpi_info acpiinfo; +gboolean using_acpi; +int acpi_count; -+int acpiwatch; +struct apm_info apminfo; + +gboolean acpi_freebsd_read(struct apm_info *apminfo, struct acpi_info *acpiinfo); -+ -+gboolean acpi_callback (gpointer data) -+{ -+ if (acpi_process_event(&acpiinfo)) { -+ acpi_freebsd_read(&apminfo, &acpiinfo); -+ } -+ -+ return TRUE; -+} #define APMDEVICE "/dev/apm" -@@ -86,25 +104,37 @@ +@@ -86,25 +94,37 @@ FreeBSD. Each time this functions is called (once every second) the APM device is opened, read from and then closed. */ @@ -383,21 +373,21 @@ - close(fd); + close(fd); ++ ++ if(apminfo.ai_status == 0) ++ return ERR_APM_E; - if(apminfo.ai_status == 0) - return ERR_APM_E; -+ if(apminfo.ai_status == 0) -+ return ERR_APM_E; -+ + } + + if (using_acpi) { -+ acpiwatch = g_timeout_add (5000, acpi_callback, NULL); ++ acpi_freebsd_read(&apminfo, &acpiinfo); + } status->present = TRUE; status->on_ac_power = apminfo.ai_acline ? 1 : 0; -@@ -339,6 +369,13 @@ +@@ -339,6 +359,13 @@ G_IO_IN | G_IO_ERR | G_IO_HUP, acpi_callback, NULL); } @@ -411,16 +401,13 @@ #endif pm_initialised = 1; -@@ -360,6 +397,13 @@ +@@ -360,6 +387,10 @@ g_source_remove(acpiwatch); acpiwatch = 0; acpi_linux_cleanup(&acpiinfo); + } +#elif defined(__FreeBSD__) + if (using_acpi) { -+ if (acpiwatch != 0) -+ g_source_remove(acpiwatch); -+ acpiwatch = 0; + acpi_freebsd_cleanup(&acpiinfo); } #endif diff --git a/x11/gnomeapplets2/files/patch-battstat-acpi b/x11/gnomeapplets2/files/patch-battstat-acpi index 7c8e5d413..38aa935c1 100644 --- a/x11/gnomeapplets2/files/patch-battstat-acpi +++ b/x11/gnomeapplets2/files/patch-battstat-acpi @@ -66,7 +66,7 @@ + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Street #330, Boston, MA 02111-1307, USA. + * -+ $Id: patch-battstat-acpi,v 1.8 2005-02-13 06:46:10 marcus Exp $ ++ $Id: patch-battstat-acpi,v 1.9 2005-02-14 01:45:28 marcus Exp $ + */ + +/* @@ -322,8 +322,8 @@ }; --- battstat/power-management.c.orig Thu Jan 13 23:06:40 2005 -+++ battstat/power-management.c Sun Feb 13 01:42:21 2005 -@@ -76,6 +76,24 @@ ++++ battstat/power-management.c Sun Feb 13 20:44:23 2005 +@@ -76,6 +76,14 @@ #ifdef __FreeBSD__ #include <machine/apm_bios.h> @@ -332,23 +332,13 @@ +struct acpi_info acpiinfo; +gboolean using_acpi; +int acpi_count; -+int acpiwatch; +struct apm_info apminfo; + +gboolean acpi_freebsd_read(struct apm_info *apminfo, struct acpi_info *acpiinfo); -+ -+gboolean acpi_callback (gpointer data) -+{ -+ if (acpi_process_event(&acpiinfo)) { -+ acpi_freebsd_read(&apminfo, &acpiinfo); -+ } -+ -+ return TRUE; -+} #define APMDEVICE "/dev/apm" -@@ -86,25 +104,37 @@ +@@ -86,25 +94,37 @@ FreeBSD. Each time this functions is called (once every second) the APM device is opened, read from and then closed. */ @@ -383,21 +373,21 @@ - close(fd); + close(fd); ++ ++ if(apminfo.ai_status == 0) ++ return ERR_APM_E; - if(apminfo.ai_status == 0) - return ERR_APM_E; -+ if(apminfo.ai_status == 0) -+ return ERR_APM_E; -+ + } + + if (using_acpi) { -+ acpiwatch = g_timeout_add (5000, acpi_callback, NULL); ++ acpi_freebsd_read(&apminfo, &acpiinfo); + } status->present = TRUE; status->on_ac_power = apminfo.ai_acline ? 1 : 0; -@@ -339,6 +369,13 @@ +@@ -339,6 +359,13 @@ G_IO_IN | G_IO_ERR | G_IO_HUP, acpi_callback, NULL); } @@ -411,16 +401,13 @@ #endif pm_initialised = 1; -@@ -360,6 +397,13 @@ +@@ -360,6 +387,10 @@ g_source_remove(acpiwatch); acpiwatch = 0; acpi_linux_cleanup(&acpiinfo); + } +#elif defined(__FreeBSD__) + if (using_acpi) { -+ if (acpiwatch != 0) -+ g_source_remove(acpiwatch); -+ acpiwatch = 0; + acpi_freebsd_cleanup(&acpiinfo); } #endif |