On Wednesday 03 January 2007 10:18, Jan Beulich wrote:
> Add a load option to intel-rng to allow skipping the FWH detection,
> necessary in case the BIOS has locked read-only the firmware hub space.
> Also prevent any attempt to write to firmware space if it cannot be
> write enabled (apparently caused hangs on some systems not having an
> FWH and thus also not having a respective RNG).
> 
> Signed-off-by: Jan Beulich <[EMAIL PROTECTED]>
> 
> --- linux-2.6.20-rc3/drivers/char/hw_random/intel-rng.c       2006-11-29 
> 22:57:37.000000000 +0100
> +++ 2.6.20-rc3-intel-rng-skip-fhw-detect/drivers/char/hw_random/intel-rng.c   
> 2006-11-29 09:09:21.000000000 +0100
> @@ -143,6 +143,8 @@ static const struct pci_device_id pci_tb
>  };
>  MODULE_DEVICE_TABLE(pci, pci_tbl);
>  
> +static __initdata int no_fwh_detect;
> +module_param(no_fwh_detect, int, 0);

I'd say we need some parameter description saying that
-1 == always skip and 1 == skip if R/O.
Otherwise this is quite confusing.

>  static inline u8 hwstatus_get(void __iomem *mem)
>  {
> @@ -240,6 +242,11 @@ static int __init mod_init(void)
>       if (!dev)
>               goto out; /* Device not found. */
>  
> +     if (no_fwh_detect < 0) {
> +             pci_dev_put(dev);
> +             goto fwh_done;
> +     }
> +
>       /* Check for Intel 82802 */
>       if (dev->device < 0x2640) {
>               fwh_dec_en1_off = FWH_DEC_EN1_REG_OLD;
> @@ -252,6 +259,23 @@ static int __init mod_init(void)
>       pci_read_config_byte(dev, fwh_dec_en1_off, &fwh_dec_en1_val);
>       pci_read_config_byte(dev, bios_cntl_off, &bios_cntl_val);
>  
> +     if ((bios_cntl_val &
> +          (BIOS_CNTL_LOCK_ENABLE_MASK|BIOS_CNTL_WRITE_ENABLE_MASK))
> +         == BIOS_CNTL_LOCK_ENABLE_MASK) {
> +             static __initdata /*const*/ char warning[] =
> +                     KERN_WARNING PFX "Firmware space is locked read-only. 
> If you can't or\n"
> +                     KERN_WARNING PFX "don't want to disable this in 
> firmware setup, and if\n"
> +                     KERN_WARNING PFX "you are certain that your system has 
> a functional\n"
> +                     KERN_WARNING PFX "RNG, try using the 'no_fwh_detect' 
> option.\n";
> +
> +             pci_dev_put(dev);
> +             if (no_fwh_detect)
> +                     goto fwh_done;
> +             printk(warning);
> +             err = -EBUSY;
> +             goto out;
> +     }
> +
>       mem = ioremap_nocache(INTEL_FWH_ADDR, INTEL_FWH_ADDR_LEN);
>       if (mem == NULL) {
>               pci_dev_put(dev);
> @@ -280,8 +304,7 @@ static int __init mod_init(void)
>               pci_write_config_byte(dev,
>                                     fwh_dec_en1_off,
>                                     fwh_dec_en1_val | FWH_F8_EN_MASK);
> -     if (!(bios_cntl_val &
> -           (BIOS_CNTL_LOCK_ENABLE_MASK|BIOS_CNTL_WRITE_ENABLE_MASK)))
> +     if (!(bios_cntl_val & BIOS_CNTL_WRITE_ENABLE_MASK))
>               pci_write_config_byte(dev,
>                                     bios_cntl_off,
>                                     bios_cntl_val | 
> BIOS_CNTL_WRITE_ENABLE_MASK);
> @@ -315,6 +338,8 @@ static int __init mod_init(void)
>               goto out;
>       }
>  
> +fwh_done:
> +
>       err = -ENOMEM;
>       mem = ioremap(INTEL_RNG_ADDR, INTEL_RNG_ADDR_LEN);
>       if (!mem)
> 
> 
> 
> 

-- 
Greetings Michael.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to