[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v2 05/14] spapr_pci: add get/set-power-level RTA
From: |
Alexey Kardashevskiy |
Subject: |
Re: [Qemu-devel] [PATCH v2 05/14] spapr_pci: add get/set-power-level RTAS interfaces |
Date: |
Mon, 16 Dec 2013 14:09:09 +1100 |
User-agent: |
Mozilla/5.0 (X11; Linux i686 on x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.2.0 |
On 12/06/2013 09:32 AM, Michael Roth wrote:
> From: Nathan Fontenot <address@hidden>
>
> Signed-off-by: Nathan Fontenot <address@hidden>
> Signed-off-by: Michael Roth <address@hidden>
> ---
> hw/ppc/spapr_pci.c | 22 ++++++++++++++++++++++
> 1 file changed, 22 insertions(+)
>
> diff --git a/hw/ppc/spapr_pci.c b/hw/ppc/spapr_pci.c
> index 1046ec8..8df44a3 100644
> --- a/hw/ppc/spapr_pci.c
> +++ b/hw/ppc/spapr_pci.c
> @@ -488,6 +488,26 @@ static void rtas_set_indicator(PowerPCCPU *cpu,
> sPAPREnvironment *spapr,
> rtas_st(rets, 0, RTAS_OUT_SUCCESS);
> }
>
> +static void rtas_set_power_level(PowerPCCPU *cpu, sPAPREnvironment *spapr,
> + uint32_t token, uint32_t nargs,
> + target_ulong args, uint32_t nret,
> + target_ulong rets)
> +{
> + uint32_t power_lvl = rtas_ld(args, 1);
> + rtas_st(rets, 0, RTAS_OUT_SUCCESS);
> + rtas_st(rets, 1, power_lvl);
> +}
> +
> +static void rtas_get_power_level(PowerPCCPU *cpu, sPAPREnvironment *spapr,
> + uint32_t token, uint32_t nargs,
> + target_ulong args, uint32_t nret,
> + target_ulong rets)
> +{
> + /* return SUCCESS with a power level of 100 */
> + rtas_st(rets, 0, RTAS_OUT_SUCCESS);
> + rtas_st(rets, 1, 100);
> +}
> +
The PAPR spec says that rtas_set_power_level() returns "Actual_level The
power level actually set" but rtas_get_power_level() always returns 100
(full power).
Is this inconsistency here for a reason?
> static int pci_spapr_swizzle(int slot, int pin)
> {
> return (slot + pin) % PCI_NUM_PINS;
> @@ -1051,6 +1071,8 @@ void spapr_pci_rtas_init(void)
> spapr_rtas_register("ibm,change-msi", rtas_ibm_change_msi);
> }
> spapr_rtas_register("set-indicator", rtas_set_indicator);
> + spapr_rtas_register("set-power-level", rtas_set_power_level);
> + spapr_rtas_register("get-power-level", rtas_get_power_level);
> }
>
> static void spapr_pci_register_types(void)
>
--
Alexey
- [Qemu-devel] [PATCH v2 06/14] spapr_pci: add get-sensor-state RTAS interface, (continued)
- [Qemu-devel] [PATCH v2 06/14] spapr_pci: add get-sensor-state RTAS interface, Michael Roth, 2013/12/05
- [Qemu-devel] [PATCH v2 03/14] spapr: add helper to retrieve a PHB/device DrcEntry, Michael Roth, 2013/12/05
- [Qemu-devel] [PATCH v2 07/14] spapr_pci: add ibm, configure-connector RTAS interface, Michael Roth, 2013/12/05
- [Qemu-devel] [PATCH v2 09/14] pci: make pci_bar useable outside pci.c, Michael Roth, 2013/12/05
- [Qemu-devel] [PATCH v2 04/14] spapr_pci: add set-indicator RTAS interface, Michael Roth, 2013/12/05
- [Qemu-devel] [PATCH v2 01/14] spapr: populate DRC entries for root dt node, Michael Roth, 2013/12/05
- [Qemu-devel] [PATCH v2 05/14] spapr_pci: add get/set-power-level RTAS interfaces, Michael Roth, 2013/12/05
- Re: [Qemu-devel] [PATCH v2 05/14] spapr_pci: add get/set-power-level RTAS interfaces,
Alexey Kardashevskiy <=
- [Qemu-devel] [PATCH v2 08/14] memory: add memory_region_find_subregion, Michael Roth, 2013/12/05
- [Qemu-devel] [PATCH v2 11/14] spapr_pci: enable basic hotplug operations, Michael Roth, 2013/12/05
- [Qemu-devel] [PATCH v2 10/14] pci: allow 0 address for PCI IO regions, Michael Roth, 2013/12/05
- Re: [Qemu-devel] [PATCH v2 10/14] pci: allow 0 address for PCI IO regions, Michael S. Tsirkin, 2013/12/12
[Qemu-devel] [PATCH v2 12/14] spapr_events: re-use EPOW event infrastructure for hotplug events, Michael Roth, 2013/12/05