On 18/12/15 11:02, Mark Rutland wrote:
> On Thu, Dec 17, 2015 at 07:56:36PM +0800, MaJun wrote:
>> From: Ma Jun <majun...@huawei.com>
>>
>> For peripheral devices which connect to mbigen,mbigen is a interrupt
>> controller. So, we create irq domain for each mbigen device and add
>> mbigen irq domain into irq hierarchy structure.
>>
>> Signed-off-by: Ma Jun <majun...@huawei.com>
>> ---
>>  drivers/irqchip/irq-mbigen.c |  138 
>> ++++++++++++++++++++++++++++++++++++++++++
>>  1 files changed, 138 insertions(+), 0 deletions(-)
> 
> [...]
> 
>> +static int mbigen_domain_translate(struct irq_domain *d,
>> +                                struct irq_fwspec *fwspec,
>> +                                unsigned long *hwirq,
>> +                                unsigned int *type)
>> +{
>> +    if (is_of_node(fwspec->fwnode)) {
>> +            if (fwspec->param_count != 2)
>> +                    return -EINVAL;
>> +
>> +            if ((fwspec->param[0] > MAXIMUM_IRQ_PIN_NUM) ||
>> +                    (fwspec->param[0] < RESERVED_IRQ_PER_MBIGEN_CHIP))
>> +                    return -EINVAL;
>> +            else
>> +                    *hwirq = fwspec->param[0];
>> +
>> +            /* If there is no valid irq type, just use the default type */
>> +            if ((fwspec->param[1] == IRQ_TYPE_EDGE_RISING) ||
>> +                    (fwspec->param[1] == IRQ_TYPE_LEVEL_HIGH))
>> +                    *type = fwspec->param[1];
>> +            else
>> +                    *type = IRQ_TYPE_NONE;
> 
> That does not seem like a good idea. The binding requires one of two
> types, and the DT is clearly wrong in the else case. 
> 
> I think for the else case we should return -EINVAL.

Ah, nicely spotted. I'll fix that in my tree too.

Thanks,

        M.
-- 
Jazz is not dead. It just smells funny...
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
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