|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH v3 1/2] xen/arm: Start to implement an ARM decoder instruction
On 07/31/2013 04:34 PM, Ian Campbell wrote:
> On Wed, 2013-07-31 at 15:49 +0100, Julien Grall wrote:
>> Some erratas on ARM processor requires to decode the instruction.
>> The decoder will, obviously, decode and fill the ISS fields of the hsr_dabt.
>>
>> For the moment, the decoder only supports:
>> - THUMB2 store instruction
>> - THUMB single load/store instruction
>>
>> Signed-off-by: Julien Grall <julien.grall@xxxxxxxxxx>
>> ---
>> xen/arch/arm/Makefile | 1 +
>> xen/arch/arm/decode.c | 143
>> +++++++++++++++++++++++++++++++++++++++++++++++++
>> xen/arch/arm/decode.h | 38 +++++++++++++
>> 3 files changed, 182 insertions(+)
>> create mode 100644 xen/arch/arm/decode.c
>> create mode 100644 xen/arch/arm/decode.h
>>
>> diff --git a/xen/arch/arm/Makefile b/xen/arch/arm/Makefile
>> index 5ae5831..5c13a65 100644
>> --- a/xen/arch/arm/Makefile
>> +++ b/xen/arch/arm/Makefile
>> @@ -30,6 +30,7 @@ obj-y += vtimer.o
>> obj-y += vpl011.o
>> obj-y += hvm.o
>> obj-y += device.o
>> +obj-y += decode.o
>>
>> #obj-bin-y += ....o
>>
>> diff --git a/xen/arch/arm/decode.c b/xen/arch/arm/decode.c
>> new file mode 100644
>> index 0000000..e432d2a
>> --- /dev/null
>> +++ b/xen/arch/arm/decode.c
>> @@ -0,0 +1,143 @@
>> +/*
>> + * xen/arch/arm/decode.c
>> + *
>> + * Instruction decoder
>> + *
>> + * Julien Grall <julien.grall@xxxxxxxxxx>
>> + * Copyright (C) 2013 Linaro Limited.
>> + *
>> + * This program is free software; you can redistribute it and/or modify
>> + * it under the terms of the GNU General Public License as published by
>> + * the Free Software Foundation; either version 2 of the License, or
>> + * (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
>> + * GNU General Public License for more details.
>> + */
>> +
>> +#include <xen/types.h>
>> +#include <xen/sched.h>
>> +#include <asm/current.h>
>> +#include <asm/guest_access.h>
>> +#include <xen/lib.h>
>> +
>> +#include "decode.h"
>> +
>> +/* TODO: Handle all THUMB2 instruction other than simple store */
>
> I think we can take it as a given that things will be added as and when
> they are required, no need to mention it IMHO.
I will remove it.
>> +static int decode_thumb2(register_t pc, struct hsr_dabt *dabt, uint16_t hw1)
>> +{
>> + uint16_t hw2;
>> + int rc;
>> + uint16_t op1, op2, op;
>> +
>> + rc = raw_copy_from_guest(&hw2, (void *__user)(pc + 2), sizeof (hw2));
>> + if ( rc )
>> + return rc;
>> +
>> + /* See A6.3 of DDI 0406C.b */
>> + op1 = (hw1 >> 11) & 0x3;
>> + op2 = (hw1 >> 4) & 0x7f;
>> + op = hw2 >> 15;
>> +
>> + if ( op1 == 3 && ((op2 & 0x71) == 0x00) )
>
> Please can we do the op1 decode with a switch. I know there is only one
> case now but it will avoid the temptation to add a chain of elses.
> op2 decoding is a pain. oh well.
>> + {
>> + /* Store single data item */
>> + dabt->reg = (hw2 >> 12) & 0x7;
>> + /* TODO: Handle access size */
>
> Is this difficult to do? Perhaps you need to just decode op2 a bit
> further?
It was for simplicity. I will add the support on the next patch series.
> Having done that it may turn out to be easier to decode op1 and op2
> together as a single switch statement.
Sounds good. I will give a try.
>> + return 0;
>> + }
>> +
>> + printk("DOM%u: unhandled THUMB2 instruction 0x%x%x\n",
>> + current->domain->domain_id, hw1, hw2);
>> +
>> + return 1;
>> +}
>> +
>> +/* TODO: Handle all THUMB instructions other than store */
>> +static int decode_thumb(register_t pc, struct hsr_dabt *dabt)
>> +{
>> + uint16_t instr;
>> + int rc;
>> +
>> + rc = raw_copy_from_guest(&instr, (void * __user)pc, sizeof (instr));
>> + if ( rc )
>> + return rc;
>> +
>> + switch ( instr >> 12 )
>> + {
>> + case 5:
>> + {
>> + /* Load/Store register */
>> + uint16_t opB = (instr >> 9) & 0x7;
>> +
>> + switch ( opB & 0x3 )
>> + {
>> + case 0:
>> + dabt->size = 2;
>> + break;
>> + case 1:
>> + dabt->size = 1;
>
> ->sign is uninitialised for these two cases?
>
> Actually, for many of them I think?
I plan to zeroed the ISS field (ie sign, reg...) by default. See TODO in
decode_instruction. Do I still need to set sign to 0?
>> + break;
>> + case 3:
>> + dabt->sign = 1;
>> + /* Fall-through */
>> + case 2:
>> + dabt->size = 0;
>> + break;
>> + }
>> +
>> + dabt->reg = instr & 7;
>> +
>> + break;
>> + }
>> + case 6:
>> + /* Load/Store word immediate offset */
>> + dabt->size = 2;
>> + dabt->reg = instr & 7;
>> + break;
>> + case 7:
>> + /* Load/Store byte immediate offset */
>> + dabt->size = 0;
>> + dabt->reg = instr & 7;
>> + break;
>> + case 8:
>> + /* Load/Store halfword immediate offset */
>> + dabt->size = 1;
>> + dabt->reg = instr & 7;
>> + break;
>> + case 9:
>> + /* Load/Store word sp offset */
>> + dabt->size = 2;
>> + dabt->reg = (instr >> 8) & 7;
>> + break;
>> + case 14:
>> + if ( instr & (1 << 11) )
>> + return decode_thumb2(pc, dabt, instr);
>> + goto bad_thumb;
>> + case 15:
>> + return decode_thumb2(pc, dabt, instr);
>> + default:
>> + goto bad_thumb;
>> + }
>> +
>> + return 0;
>> +
>> +bad_thumb:
>> + printk("DOM%u: unhandled THUMB instruction 0x%x\n",
>> + current->domain->domain_id, instr);
>> + return 1;
>> +}
>> +
>> +int decode_instruction(const struct cpu_user_regs *regs, struct hsr_dabt
>> *dabt)
>> +{
>> + /* XXX: zeroed ISS when decode will be fully implemented */
>> +
>> + if ( regs->cpsr & PSR_THUMB )
>> + return decode_thumb(regs->pc, dabt);
>
> Needs an is_pv32_domain too.
I will add in the next patch series.
>> +
>> + /* TODO: Handle ARM instruction */
>> +
>> + return 1;
>> +}
>> diff --git a/xen/arch/arm/decode.h b/xen/arch/arm/decode.h
>> new file mode 100644
>> index 0000000..dc130a3
>> --- /dev/null
>> +++ b/xen/arch/arm/decode.h
>> @@ -0,0 +1,38 @@
>> +/*
>> + * xen/arch/arm/decode.h
>> + *
>> + * Instruction decoder
>> + *
>> + * Julien Grall <julien.grall@xxxxxxxxxx>
>> + * Copyright (C) 2013 Linaro Limited.
>> + *
>> + * This program is free software; you can redistribute it and/or modify
>> + * it under the terms of the GNU General Public License as published by
>> + * the Free Software Foundation; either version 2 of the License, or
>> + * (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
>> + * GNU General Public License for more details.
>> + */
>> +
>> +#ifndef __ARCH_ARM_DECODE_H_
>> +#define __ARCH_ARM_DECODE_H_
>> +
>> +#include <asm/regs.h>
>> +#include <asm/processor.h>
>> +
>> +int decode_instruction(const struct cpu_user_regs *regs,
>> + struct hsr_dabt *dabt);
>> +
>> +#endif /* __ARCH_ARM_DECODE_H_ */
>> +
>> +/*
>> + * Local variables:
>> + * mode: C
>> + * c-file-style: "BSD"
>> + * c-basic-offset: 4
>> + * indent-tabs-mode: nil
>> + * End:
>> + */
>
>
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |