+2009-01-16 Adam Nemet <anemet@caviumnetworks.com>
+
+ PR target/38554
+ * expmed.c (expand_shift): With SHIFT_COUNT_TRUNCATED, don't lift
+ the subreg from a lowpart subreg if it is also casting the value.
+
2009-01-16 Sebastian Pop <sebastian.pop@amd.com>
Tobias Grosser <tobi.grosser@amd.com>
op1 = GEN_INT ((unsigned HOST_WIDE_INT) INTVAL (op1)
% GET_MODE_BITSIZE (mode));
else if (GET_CODE (op1) == SUBREG
- && subreg_lowpart_p (op1))
+ && subreg_lowpart_p (op1)
+ && INTEGRAL_MODE_P (GET_MODE (SUBREG_REG (op1))))
op1 = SUBREG_REG (op1);
}
--- /dev/null
+typedef unsigned long sample;
+struct pam
+{
+ sample maxval;
+};
+typedef sample *tuple;
+enum function
+ {
+ FN_MULTIPLY, FN_DIVIDE, FN_ADD, FN_SUBTRACT, FN_MIN, FN_MAX, FN_AND, FN_OR,
+ FN_XOR, FN_NOT, FN_SHIFTLEFT, FN_SHIFTRIGHT
+ };
+struct cmdlineInfo
+{
+ enum function function;
+ union
+ {
+ float divisor;
+ unsigned int shiftCount;
+ }
+ u;
+};
+applyFunction (struct cmdlineInfo const cmdline, struct pam const inpam,
+ struct pam const outpam, tuple * const inputRow,
+ tuple * const outputRow)
+{
+ float const oneOverDivisor = 1 / cmdline.u.divisor;
+ int col;
+ {
+ int plane;
+ {
+ sample const inSample = inputRow[col][plane];
+ sample outSample;
+ switch (cmdline.function)
+ {
+ case FN_DIVIDE:
+ outSample = ((unsigned int) ((inSample * oneOverDivisor) + 0.5));
+ break;
+ case FN_SHIFTLEFT:
+ outSample = (inSample << cmdline.u.shiftCount) & outpam.maxval;
+ }
+ outputRow[col][plane] =
+ ((outpam.maxval) < (outSample) ? (outpam.maxval) : (outSample));
+ }
+ }
+}