cpufreq Archive on lore.kernel.org
 help / color / mirror / Atom feed
From: Lutz Vieweg <lkv@isg.de>
To: Pavel Machek <pavel@suse.cz>
Cc: patches@x86-64.org, cpufreq@www.linux.org.uk
Subject: Re: [patches] 2.6.2 to 2.6.3 regression: powernow-k8 doesn't work anymore
Date: Mon, 01 Mar 2004 11:12:40 +0100	[thread overview]
Message-ID: <40430C98.3020702@isg.de> (raw)
In-Reply-To: <20040228001649.GJ425@elf.ucw.cz>

Pavel Machek wrote:

>>A factor 1000 lost somewhere?
> 
> Yes.
> 
> Try this one. [Warning: extremely ugly hand-edited patch follows;
> taking akpm off Cc list, I do not want him to even see it]

This second patch (applied addtionally to the first one) fixes
the cpufreq behaviour for the K8V board - thanks!

Regards,

Lutz Vieweg

> 
> --- clean/arch/i386/kernel/cpu/cpufreq/powernow-k8.c	2004-02-20 12:29:10.000000000 +0100
> +++ linux/arch/i386/kernel/cpu/cpufreq/powernow-k8.c	2004-02-23 21:06:01.000000000 +0100
> @@ -8,6 +8,8 @@
>   *
>   *  Based on the powernow-k7.c module written by Dave Jones.
>   *  (C) 2003 Dave Jones <davej@codemonkey.ork.uk> on behalf of SuSE Labs
> + *  (C) 2004 Dominik Brodowski <linux@brodo.de>
> + *  (C) 2004 Pavel Machek <pavel@suse.cz>
>   *  Licensed under the terms of the GNU GPL License version 2.
>   *  Based upon datasheets & sample CPUs kindly provided by AMD.
>   *
> @@ -34,10 +36,6 @@
>  #define VERSION "version 1.00.08a"
>  #include "powernow-k8.h"
>  
> -#ifdef CONFIG_PREEMPT
> -#warning this driver has not been tested on a preempt system
> -#endif
> -
>  static u32 vstable;	/* voltage stabalization time, from PSB, units 20 us */
>  static u32 plllock;	/* pll lock time, from PSB, units 1 us */
>  static u32 numps;	/* number of p-states, from PSB */
> @@ -521,7 +519,8 @@
>  		}
>  		if ((pst[j].fid > MAX_FID)
>  		    || (pst[j].fid & 1)
> -		    || (pst[j].fid < HI_FID_TABLE_BOTTOM)){
> +		    || (j && (pst[j].fid < HI_FID_TABLE_BOTTOM))) {
> +			/* Only first fid is allowed to be in "low" range */
>  			printk(KERN_ERR PFX "fid %d invalid : 0x%x\n", j, pst[j].fid);
>  			return -EINVAL;
>  		}
> @@ -548,6 +547,7 @@
>  	unsigned int i, j;
>  	u32 mvs;
>  	u8 maxvid;
> +	int arima = 0;
>  
>  	for (i = 0xc0000; i < 0xffff0; i += 0x10) {
>  		/* Scan BIOS looking for the signature. */
> @@ -589,7 +589,7 @@
>  		dprintk(KERN_DEBUG PFX "numpst: 0x%x\n", psb->numpst);
>  		if (psb->numpst != 1) {
>  			printk(KERN_ERR BFX "numpst must be 1\n");
> -			return -ENODEV;
> +			arima = 0;
>  		}
>  
>  		dprintk(KERN_DEBUG PFX "cpuid: 0x%x\n", psb->cpuid);
> @@ -601,7 +601,7 @@
>  		printk("maxfid 0x%x (%d MHz), maxvid 0x%x\n", 
>  		       psb->maxfid, find_freq_from_fid(psb->maxfid), maxvid);
>  
> -		numps = psb->numpstates;
> +		numps = arima ? 3 : psb->numpstates;
>  		if (numps < 2) {
>  			printk(KERN_ERR BFX "no p states to transition\n");
>  			return -ENODEV;
> @@ -626,8 +626,10 @@
>  		}
>  
>  		pst = (struct pst_s *) (psb + 1);
> -		if (check_pst_table(pst, maxvid))
> -			return -EINVAL;
> +		if (check_pst_table(pst, maxvid)) {
> +			if (!arima)
> +				return -EINVAL;
> +		}
>  
>  		powernow_table = kmalloc((sizeof(struct cpufreq_frequency_table) * (numps + 1)), GFP_KERNEL);
>  		if (!powernow_table) {
> @@ -635,13 +637,24 @@
>  			return -ENOMEM;
>  		}
>  
> -		for (j = 0; j < numps; j++) {
> -			printk(KERN_INFO PFX "   %d : fid 0x%x (%d MHz), vid 0x%x\n", j,
> -			       pst[j].fid, find_freq_from_fid(pst[j].fid), pst[j].vid);
> +		for (j = 0; j < numps; j++) {
>  			powernow_table[j].index = pst[j].fid; /* lower 8 bits */
>  			powernow_table[j].index |= (pst[j].vid << 8); /* upper 8 bits */
> -			powernow_table[j].frequency = find_freq_from_fid(pst[j].fid);
>  		}
> +
> +		if (arima) {
> +			powernow_table[1].index = 0x0608;
> +			powernow_table[2].index = 0x020a;
> +		}
> +
> +		for (j = 0; j < numps; j++) {
> +			powernow_table[j].frequency = find_freq_from_fid(powernow_table[j].index & 0xff)*1000;
> +			printk(KERN_INFO PFX "   %d : fid 0x%x (%d MHz), vid 0x%x\n", j,
> +			       powernow_table[j].index & 0xff, 
> +			       powernow_table[j].frequency/1000,
> +			       powernow_table[j].index >> 8);
> +		}
> +
>  		powernow_table[numps].frequency = CPUFREQ_TABLE_END;
>  		powernow_table[numps].index = 0;
>  
> 
> 

      parent reply	other threads:[~2004-03-01 10:12 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <4038ED24.3080402@isg.de>
     [not found] ` <20040222231431.GA24835@elf.ucw.cz>
     [not found]   ` <403E8248.2040902@isg.de>
2004-02-28  0:16     ` [patches] 2.6.2 to 2.6.3 regression: powernow-k8 doesn't work anymore Pavel Machek
2004-02-28 13:15       ` Pavel Machek
2004-03-01 10:15         ` Lutz Vieweg
2004-03-01 10:12       ` Lutz Vieweg [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=40430C98.3020702@isg.de \
    --to=lkv@isg.de \
    --cc=cpufreq@www.linux.org.uk \
    --cc=patches@x86-64.org \
    --cc=pavel@suse.cz \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox