Displaying 3 results from an estimated 3 matches for "mulqi".
Did you mean:
muli
2012 Oct 08
1
[LLVMdev] Multiply i8 operands promotes to i32
> At -O0, you don't. __mulsi3 is the obvious lowering, and you're doing
> something wrong if your tools don't provide it.
MSP430 is 16 bit target, so mulsi is a bit expensive there, mulhi /
mulqi can be implemented via hardware multiplier.
There are several problems wrt 16 bit support inside LLVM in general
and msp430 in particular:
1. In some places LLVM expectes 32 bit or 64 bit target (e.g. i32
arguments length argument of memcpy, etc.)
2. On MSP430 the multiplier is an external device...
2012 Oct 08
0
[LLVMdev] Multiply i8 operands promotes to i32
On Mon, Oct 8, 2012 at 2:44 AM, Pedro Malagón <malagon at die.upm.es> wrote:
> Hi,
>
> I am trying to complete the hardware multiplier option for MSP430 backend.
>
> As the hardware multiplier in most of the MSP430 devices is for i8 and
> i16 operands, with i16 and i32 result, I am lowering MUL_i8 and MUL_I16.
> However, the front-end promotes the i8 argument to i32,
2012 Oct 08
3
[LLVMdev] Multiply i8 operands promotes to i32
Hi,
I am trying to complete the hardware multiplier option for MSP430 backend.
As the hardware multiplier in most of the MSP430 devices is for i8 and
i16 operands, with i16 and i32 result, I am lowering MUL_i8 and MUL_I16.
However, the front-end promotes the i8 argument to i32, executes 32-bit
multiplier and truncates to 16-bit, so I never lower MUL_I8 nor MUL_I16
but MUL_I32, wchich is lowered