case dump_node_mode_txt:
mode = get_irn_mode(n);
- if (is_ia32_Load(n)) {
- mode = get_irn_mode(get_irn_n(n, 0));
- }
- else if (is_ia32_Store(n)) {
- mode = get_irn_mode(get_irn_n(n, 2));
+ if (is_ia32_Load(n) || is_ia32_Store(n)) {
+ mode = get_ia32_ls_mode(n);
}
if (mode) {
fprintf(F, "[%s]", get_mode_name(mode));
}
+ else {
+ fprintf(F, "[?NOMODE?]");
+ }
break;
case dump_node_nodeattr_txt:
fprintf(F, "[%s%s]", pref, get_ia32_cnst(n));
}
- if (is_ia32_AddrModeS(n)) {
- fprintf(F, "[AM S] ");
- }
- else if (is_ia32_AddrModeD(n)) {
- fprintf(F, "[AM D] ");
+ if (! is_ia32_Lea(n)) {
+ if (is_ia32_AddrModeS(n)) {
+ fprintf(F, "[AM S] ");
+ }
+ else if (is_ia32_AddrModeD(n)) {
+ fprintf(F, "[AM D] ");
+ }
}
break;
return attr->cnst;
}
+/**
+ * Gets the mode of the stored/loaded value (only set for Store/Load)
+ */
+ir_mode *get_ia32_ls_mode(const ir_node *node) {
+ ia32_attr_t *attr = get_ia32_attr(node);
+ return attr->ls_mode;
+}
+
+/**
+ * Sets the mode of the stored/loaded value (only set for Store/Load)
+ */
+void set_ia32_ls_mode(ir_node *node, ir_mode *mode) {
+ ia32_attr_t *attr = get_ia32_attr(node);
+ attr->ls_mode = mode;
+}
+
/**
* Returns the argument register requirements of an ia32 node.
*/
*/
char *get_ia32_cnst(ir_node *node);
+/**
+ * Gets the mode of the stored/loaded value (only set for Store/Load)
+ */
+ir_mode *get_ia32_ls_mode(const ir_node *node);
+
+/**
+ * Sets the mode of the stored/loaded value (only set for Store/Load)
+ */
+void set_ia32_ls_mode(ir_node *node, ir_mode *mode);
+
/**
* Returns the argument register requirements of an ia32 node.
*/
char *sc; /**<< symconst name */
char *cnst; /**<< points to the string representation of the constant value (either tv or sc) */
+ ir_mode *ls_mode; /**<< the mode of the stored/loaded value */
+
ia32_op_flavour_t op_flav; /**<< flavour of an op (flavour_Div/Mod/DivMod/Mul/Mulh) */
long pn_code; /**<< projnum "types" (e.g. indicate compare operators and argument numbers) */
long n_res; /**<< number of results */
scale = get_tarval_long(get_ia32_Immop_tarval(temp));
if (scale <= 3) {
+ scale = 1 << scale;
index = get_irn_n(temp, 2);
DBG((mod, LEVEL_1, "\tgot scaled index %+F\n", index));
}
set_ia32_am_support(new_op, ia32_am_Source);
+ set_ia32_ls_mode(new_op, get_Load_mode(node));
+
return new_op;
}
}
set_ia32_am_support(new_op, ia32_am_Dest);
+ set_ia32_ls_mode(new_op, get_irn_mode(get_Store_value(node)));
return new_op;
}