diff options
| author | Chris Wilson <chris@chris-wilson.co.uk> | 2013-08-20 11:08:13 +0100 | 
|---|---|---|
| committer | Chris Wilson <chris@chris-wilson.co.uk> | 2013-08-20 11:08:13 +0100 | 
| commit | c888507b68c665e15d02defae9d341245c87b1c2 (patch) | |
| tree | d6569ca2b755599f75326fab5baf8385bdaa96e4 /overlay | |
| parent | cf62d52eb414db54c7dd8c78e3052fbad30f94fb (diff) | |
overlay: use rc6_enable to drop useless information
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'overlay')
| -rw-r--r-- | overlay/overlay.c | 25 | ||||
| -rw-r--r-- | overlay/rc6.c | 9 | ||||
| -rw-r--r-- | overlay/rc6.h | 2 | 
3 files changed, 28 insertions, 8 deletions
| diff --git a/overlay/overlay.c b/overlay/overlay.c index bf508fd9..0968fd71 100644 --- a/overlay/overlay.c +++ b/overlay/overlay.c @@ -20,6 +20,8 @@  #include "power.h"  #include "rc6.h" +#define is_power_of_two(x)  (((x) & ((x)-1)) == 0) +  const cairo_user_data_key_t overlay_key;  static void overlay_show(cairo_surface_t *surface) @@ -417,7 +419,6 @@ static void init_gpu_freq(struct overlay_context *ctx,  	}  	rc6_init(&gf->rc6); -  }  static void show_gpu_freq(struct overlay_context *ctx, struct overlay_gpu_freq *gf) @@ -454,9 +455,25 @@ static void show_gpu_freq(struct overlay_context *ctx, struct overlay_gpu_freq *  		sprintf(buf, "RC6: %d%%", gf->rc6.rc6_combined);  		cairo_move_to(ctx->cr, 12, y);  		cairo_show_text(ctx->cr, buf); -		if (gf->rc6.rc6_combined) { -			sprintf(buf, " [rc6=%d%%, rc6p=%d%%, rc6pp=%d%%]", -				gf->rc6.rc6, gf->rc6.rc6p, gf->rc6.rc6pp); +		if (gf->rc6.rc6_combined && !is_power_of_two(gf->rc6.enabled)) { +			len = 0; +			sprintf(buf, " ("); +			if (gf->rc6.enabled & 1) { +				if (len) +					len += sprintf(buf + 3 + len, ", "); +				len += sprintf(buf + 3 + len, "rc6=%d%%", gf->rc6.rc6); +			} +			if (gf->rc6.enabled & 2) { +				if (len) +					len += sprintf(buf + 3 + len, ", "); +				len += sprintf(buf + 3 + len, "rc6p=%d%%", gf->rc6.rc6p); +			} +			if (gf->rc6.enabled & 4) { +				if (len) +					len += sprintf(buf + 3 + len, ", "); +				len += sprintf(buf + 3 + len, "rc6pp=%d%%", gf->rc6.rc6pp); +			} +			sprintf(buf + 3 + len, ")");  			cairo_show_text(ctx->cr, buf);  		}  		y += 14; diff --git a/overlay/rc6.c b/overlay/rc6.c index 4bece6c0..1fea4444 100644 --- a/overlay/rc6.c +++ b/overlay/rc6.c @@ -63,11 +63,12 @@ int rc6_update(struct rc6 *rc6)  	if (rc6->error)  		return rc6->error; -	if (stat("/sys/class/drm/card0/power", &st) < 0) -		return rc6->error = errno; -  	if (stat("/sys/class/drm/card0/power/rc6_residency_ms", &st) < 0) -		return ENOENT; +		return rc6->error = ENOENT; + +	rc6->enabled = file_to_u64("/sys/class/drm/card0/power/rc6_enable"); +	if (rc6->enabled == 0) +		return EAGAIN;  	s->rc6_residency = file_to_u64("/sys/class/drm/card0/power/rc6_residency_ms");  	s->rc6p_residency = file_to_u64("/sys/class/drm/card0/power/rc6p_residency_ms"); diff --git a/overlay/rc6.h b/overlay/rc6.h index 3a166b69..8fb54bcc 100644 --- a/overlay/rc6.h +++ b/overlay/rc6.h @@ -11,6 +11,8 @@ struct rc6 {  	int count;  	int error; +	unsigned enabled; +  	uint8_t rc6;  	uint8_t rc6p;  	uint8_t rc6pp; | 
