On 2015/5/20 19:05, Igor Mammedov wrote:
> On Wed, 20 May 2015 12:23:02 +0800
> Shannon Zhao <zhaoshengl...@huawei.com> wrote:
> 
>> > From: Shannon Zhao <shannon.z...@linaro.org>
>> > 
>> > Add aml_interrupt() for describing device interrupt in resource template.
>> > These can be used to generating DSDT table for ACPI on ARM.
>> > 
>> > Signed-off-by: Shannon Zhao <zhaoshengl...@huawei.com>
>> > Signed-off-by: Shannon Zhao <shannon.z...@linaro.org>
>> > ---
>> >  hw/acpi/aml-build.c         | 22 ++++++++++++++++++++++
>> >  include/hw/acpi/aml-build.h | 42 
>> > ++++++++++++++++++++++++++++++++++++++++++
>> >  2 files changed, 64 insertions(+)
>> > 
>> > diff --git a/hw/acpi/aml-build.c b/hw/acpi/aml-build.c
>> > index 805a0ad..5f06367 100644
>> > --- a/hw/acpi/aml-build.c
>> > +++ b/hw/acpi/aml-build.c
>> > @@ -531,6 +531,28 @@ Aml *aml_memory32_fixed(uint32_t addr, uint32_t size,
>> >      return var;
>> >  }
>> >  
>> > +/*
>> > + * ACPI 5.0: 6.4.3.6 Extended Interrupt Descriptor
>> > + * Type 1, Large Item Name 0x9
>> > + */
>> > +Aml *aml_interrupt(AmlConsumerAndProducer con_and_pro,
>> > +                   AmlLevelAndEdge level_and_edge,
>> > +                   AmlActiveHighAndLow high_and_low, AmlShared shared,
>> > +                   uint32_t irq)
>> > +{
>> > +    Aml *var = aml_alloc();
>> > +    uint8_t irq_flags = con_and_pro | (level_and_edge << 1)
>> > +                        | (high_and_low << 2) | (shared << 3);
>> > +
>> > +    build_append_byte(var->buf, 0x89); /* Extended irq descriptor */
>> > +    build_append_byte(var->buf, 6); /* Length, bits[7:0] minimum value = 
>> > 6 */
>> > +    build_append_byte(var->buf, 0); /* Length, bits[15:8] minimum value = 
>> > 0 */
>> > +    build_append_byte(var->buf, irq_flags); /* Interrupt Vector 
>> > Information. */
>> > +    build_append_byte(var->buf, 0x01); /* Interrupt table length = 1 */
>> > +    build_append_4bytes(var->buf, irq); /* Interrupt Number */
> Just looking at the patch I have no idea what above line does;
> 
> using 4 build_append_byte() is much clearer and matches the spec 1:1
> when comparing.
> 

I feel awkward and have no word to convince you. If you insist on this,
I'll go back to 4 build_append_byte().

-- 
Shannon


Reply via email to