powerpc/pseries: Cleanup best_energy_hcall detection
Currently we search for the best_energy hcall using a custom function. Move this to using the firmware_feature_table. Signed-off-by: Michael Neuling <mikey@neuling.org> cc: Vaidyanathan Srinivasan <svaidy@linux.vnet.ibm.com> cc: Linux PPC dev <linuxppc-dev@ozlabs.org> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
This commit is contained in:
parent
2f1d4ea7bc
commit
0388c79c99
@ -50,6 +50,7 @@
|
|||||||
#define FW_FEATURE_OPAL ASM_CONST(0x0000000010000000)
|
#define FW_FEATURE_OPAL ASM_CONST(0x0000000010000000)
|
||||||
#define FW_FEATURE_OPALv2 ASM_CONST(0x0000000020000000)
|
#define FW_FEATURE_OPALv2 ASM_CONST(0x0000000020000000)
|
||||||
#define FW_FEATURE_SET_MODE ASM_CONST(0x0000000040000000)
|
#define FW_FEATURE_SET_MODE ASM_CONST(0x0000000040000000)
|
||||||
|
#define FW_FEATURE_BEST_ENERGY ASM_CONST(0x0000000080000000)
|
||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
|
|
||||||
@ -64,7 +65,7 @@ enum {
|
|||||||
FW_FEATURE_BULK_REMOVE | FW_FEATURE_XDABR |
|
FW_FEATURE_BULK_REMOVE | FW_FEATURE_XDABR |
|
||||||
FW_FEATURE_MULTITCE | FW_FEATURE_SPLPAR | FW_FEATURE_LPAR |
|
FW_FEATURE_MULTITCE | FW_FEATURE_SPLPAR | FW_FEATURE_LPAR |
|
||||||
FW_FEATURE_CMO | FW_FEATURE_VPHN | FW_FEATURE_XCMO |
|
FW_FEATURE_CMO | FW_FEATURE_VPHN | FW_FEATURE_XCMO |
|
||||||
FW_FEATURE_SET_MODE,
|
FW_FEATURE_SET_MODE | FW_FEATURE_BEST_ENERGY,
|
||||||
FW_FEATURE_PSERIES_ALWAYS = 0,
|
FW_FEATURE_PSERIES_ALWAYS = 0,
|
||||||
FW_FEATURE_POWERNV_POSSIBLE = FW_FEATURE_OPAL | FW_FEATURE_OPALv2,
|
FW_FEATURE_POWERNV_POSSIBLE = FW_FEATURE_OPAL | FW_FEATURE_OPALv2,
|
||||||
FW_FEATURE_POWERNV_ALWAYS = 0,
|
FW_FEATURE_POWERNV_ALWAYS = 0,
|
||||||
|
@ -62,6 +62,7 @@ firmware_features_table[FIRMWARE_MAX_FEATURES] = {
|
|||||||
{FW_FEATURE_SPLPAR, "hcall-splpar"},
|
{FW_FEATURE_SPLPAR, "hcall-splpar"},
|
||||||
{FW_FEATURE_VPHN, "hcall-vphn"},
|
{FW_FEATURE_VPHN, "hcall-vphn"},
|
||||||
{FW_FEATURE_SET_MODE, "hcall-set-mode"},
|
{FW_FEATURE_SET_MODE, "hcall-set-mode"},
|
||||||
|
{FW_FEATURE_BEST_ENERGY, "hcall-best-energy-1*"},
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Build up the firmware features bitmask using the contents of
|
/* Build up the firmware features bitmask using the contents of
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
#include <asm/cputhreads.h>
|
#include <asm/cputhreads.h>
|
||||||
#include <asm/page.h>
|
#include <asm/page.h>
|
||||||
#include <asm/hvcall.h>
|
#include <asm/hvcall.h>
|
||||||
|
#include <asm/firmware.h>
|
||||||
|
|
||||||
|
|
||||||
#define MODULE_VERS "1.0"
|
#define MODULE_VERS "1.0"
|
||||||
@ -32,40 +33,6 @@ static int sysfs_entries;
|
|||||||
|
|
||||||
/* Helper routines */
|
/* Helper routines */
|
||||||
|
|
||||||
/*
|
|
||||||
* Routine to detect firmware support for hcall
|
|
||||||
* return 1 if H_BEST_ENERGY is supported
|
|
||||||
* else return 0
|
|
||||||
*/
|
|
||||||
|
|
||||||
static int check_for_h_best_energy(void)
|
|
||||||
{
|
|
||||||
struct device_node *rtas = NULL;
|
|
||||||
const char *hypertas, *s;
|
|
||||||
int length;
|
|
||||||
int rc = 0;
|
|
||||||
|
|
||||||
rtas = of_find_node_by_path("/rtas");
|
|
||||||
if (!rtas)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
hypertas = of_get_property(rtas, "ibm,hypertas-functions", &length);
|
|
||||||
if (!hypertas) {
|
|
||||||
of_node_put(rtas);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* hypertas will have list of strings with hcall names */
|
|
||||||
for (s = hypertas; s < hypertas + length; s += strlen(s) + 1) {
|
|
||||||
if (!strncmp("hcall-best-energy-1", s, 19)) {
|
|
||||||
rc = 1; /* Found the string */
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
of_node_put(rtas);
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Helper Routines to convert between drc_index to cpu numbers */
|
/* Helper Routines to convert between drc_index to cpu numbers */
|
||||||
|
|
||||||
static u32 cpu_to_drc_index(int cpu)
|
static u32 cpu_to_drc_index(int cpu)
|
||||||
@ -262,7 +229,7 @@ static int __init pseries_energy_init(void)
|
|||||||
int cpu, err;
|
int cpu, err;
|
||||||
struct device *cpu_dev;
|
struct device *cpu_dev;
|
||||||
|
|
||||||
if (!check_for_h_best_energy()) {
|
if (!firmware_has_feature(FW_FEATURE_BEST_ENERGY)) {
|
||||||
printk(KERN_INFO "Hypercall H_BEST_ENERGY not supported\n");
|
printk(KERN_INFO "Hypercall H_BEST_ENERGY not supported\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user