Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 18 Apr 2005 14:35:23 +0200
From:      sebastian ssmoller <sebastian.ssmoller@gmx.net>
To:        freebsd-current@freebsd.org
Subject:   Re: powerd(8)
Message-ID:  <20050418143523.3d935084.sebastian.ssmoller@gmx.net>
In-Reply-To: <2428.1113827273@critter.freebsd.dk>
References:  <2304.1113826754@critter.freebsd.dk> <2428.1113827273@critter.freebsd.dk>

next in thread | previous in thread | raw e-mail | index | archive | help

wow - that was fast ;-)
thx - i'll give it a try today and i'll let u know how it works

thx
regards,
seb

On Mon, 18 Apr 2005 14:27:53 +0200
"Poul-Henning Kamp" <phk@phk.freebsd.dk> wrote:

> 
> Here's a patch which implements "phk" mode:
> 
> 
> Index: powerd.c
> ===================================================================
> RCS file: /home/ncvs/src/usr.sbin/powerd/powerd.c,v
> retrieving revision 1.4
> diff -u -r1.4 powerd.c
> --- powerd.c	27 Feb 2005 01:58:49 -0000	1.4
> +++ powerd.c	18 Apr 2005 12:26:03 -0000
> @@ -50,6 +50,7 @@
>  enum modes_t {
>  	MODE_MIN,
>  	MODE_ADAPTIVE,
> +	MODE_PHK,
>  	MODE_MAX,
>  };
>  
> @@ -220,6 +221,8 @@
>  		*mode = MODE_MAX;
>  	else if (strcmp(arg, "adaptive") == 0)
>  		*mode = MODE_ADAPTIVE;
> +	else if (strcmp(arg, "phk") == 0)
> +		*mode = MODE_PHK;
>  	else
>  		errx(1, "bad option: -%c %s", (char)ch, optarg);
>  }
> @@ -377,6 +380,37 @@
>  		if (read_usage_times(&idle, &total))
>  			err(1, "read_usage_times");
>  
> +		if (mode == MODE_PHK) {
> +			for (i = 0; i < numfreqs - 1; i++) {
> +				if (freqs[i] == curfreq)
> +					break;
> +			}
> +			if (idle < (total * cpu_running_mark) / 100 &&
> +			    curfreq < freqs[0]) {
> +				i -= 2;
> +				if (i < 0)
> +					i = 0;
> +				if (vflag) {
> +					printf("idle time < %d%%, increasing clock"
> +					    " speed from %d MHz to %d MHz\n",
> +					    cpu_running_mark, curfreq, freqs[i]);
> +				}
> +				if (set_freq(freqs[i]))
> +					err(1, "error setting CPU frequency %d", freqs[i]);
> +			} else if (idle > (total * cpu_idle_mark) / 100 &&
> +			    curfreq > freqs[numfreqs - 1]) {
> +				i++;
> +				if (vflag) {
> +					printf("idle time > %d%%, decreasing clock"
> +					    " speed from %d MHz to %d MHz\n",
> +					    cpu_idle_mark, curfreq, freqs[i]);
> +				}
> +				if (set_freq(freqs[i]))
> +					err(1, "error setting CPU frequency %d", freqs[i]);
> +			}
> +			continue;
> +		}
> +
>  		/*
>  		 * If we're idle less than the active mark, jump the CPU to
>  		 * its fastest speed if we're not there yet.  If we're idle
> 
> -- 
> Poul-Henning Kamp       | UNIX since Zilog Zeus 3.20
> phk@FreeBSD.ORG         | TCP/IP since RFC 956
> FreeBSD committer       | BSD since 4.3-tahoe    
> Never attribute to malice what can adequately be explained by
> incompetence. _______________________________________________
> freebsd-current@freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-current
> To unsubscribe, send any mail to
> "freebsd-current-unsubscribe@freebsd.org"
> 



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20050418143523.3d935084.sebastian.ssmoller>