[U-Boot] [PATCH 04/13] firmware: zynqmp: Add zynqmp-power support
Michal Simek
michal.simek at xilinx.com
Wed Oct 2 10:04:55 UTC 2019
On 02. 10. 19 11:34, Luca Ceresoli wrote:
> Hi Ibai, Michal,
>
> On 27/09/19 15:34, Michal Simek wrote:
>> From: Ibai Erkiaga <ibai.erkiaga-elorza at xilinx.com>
>>
>> zynqmp-power driver for ZynqMP to handle the communication with the PMU
>> firmware. Firmware driver just probes subnodes and power driver handles
>> communication with PMU using the IPI mailbox driver.
>>
>> Signed-off-by: Ibai Erkiaga <ibai.erkiaga-elorza at xilinx.com>
>> Signed-off-by: Michal Simek <michal.simek at xilinx.com>
>> ---
>>
>> drivers/firmware/Kconfig | 2 ++
>> drivers/firmware/firmware-zynqmp.c | 40 ++++++++++++++++++++++++++++++
>> 2 files changed, 42 insertions(+)
>>
>> diff --git a/drivers/firmware/Kconfig b/drivers/firmware/Kconfig
>> index b70a2063551c..9596ec16c7f7 100644
>> --- a/drivers/firmware/Kconfig
>> +++ b/drivers/firmware/Kconfig
>> @@ -30,6 +30,8 @@ config TI_SCI_PROTOCOL
>> config ZYNQMP_FIRMWARE
>> bool "ZynqMP Firmware interface"
>> select FIRMWARE
>> + select ZYNQMP_IPI
>> + select DM_MAILBOX
>> help
>> Firmware interface driver is used by different
>> drivers to communicate with the firmware for
>> diff --git a/drivers/firmware/firmware-zynqmp.c b/drivers/firmware/firmware-zynqmp.c
>> index 6644a7166ca0..b0930447b988 100644
>> --- a/drivers/firmware/firmware-zynqmp.c
>> +++ b/drivers/firmware/firmware-zynqmp.c
>> @@ -1,6 +1,46 @@
>> // SPDX-License-Identifier: GPL-2.0
>> +/*
>> + * Xilinx Zynq MPSoC Firmware driver
>> + *
>> + * Copyright (C) 2018-2019 Xilinx, Inc.
>> + */
>>
>> +#include <common.h>
>> #include <dm.h>
>> +#include <mailbox.h>
>> +#include <asm/arch/sys_proto.h>
>> +
>> +struct zynqmp_power {
>> + struct mbox_chan tx_chan;
>> + struct mbox_chan rx_chan;
>> +} zynqmp_power;
>> +
>> +static int zynqmp_power_probe(struct udevice *dev)
>> +{
>> + int ret = 0;
>> +
>> + debug("%s, (dev=%p)\n", __func__, dev);
>> +
>> + ret |= mbox_get_by_name(dev, "tx", &zynqmp_power.tx_chan);
>> + ret |= mbox_get_by_name(dev, "rx", &zynqmp_power.rx_chan);
>
> If these two calls return different error values, the binary or will
> produce a nonsense 'ret' value. E.g. (-EINVAL | -ENODATA) equals -ENOTDIR.
>
> Otherwise looks good.
>
Let's fix this. Also mbox_send/mbox_recv from firmware-zynqmp.c should
be fixed too.
Thanks,
Michal
More information about the U-Boot
mailing list