select once
This commit is contained in:
@@ -276,11 +276,13 @@ struct SynthIce40Pass : public ScriptPass
|
||||
run("techmap -map +/mul2dsp.v -map +/ice40/dsp_map.v -D DSP_A_MAXWIDTH=16 -D DSP_B_MAXWIDTH=16 "
|
||||
"-D DSP_A_MINWIDTH=2 -D DSP_B_MINWIDTH=2 -D DSP_Y_MINWIDTH=11 "
|
||||
"-D DSP_NAME=$__MUL16X16", "(if -dsp)");
|
||||
run("opt_expr -fine a:mul2dsp", " (if -dsp)");
|
||||
run("wreduce a:mul2dsp", " (if -dsp)");
|
||||
run("ice40_dsp", " (if -dsp)");
|
||||
run("setattr -unset mul2dsp a:mul2dsp", "(if -dsp)");
|
||||
run("chtype -set $mul t:$__soft_mul", " (if -dsp)");
|
||||
run("select a:mul2dsp", " (if -dsp)");
|
||||
run("opt_expr -fine", " (if -dsp)");
|
||||
run("wreduce", " (if -dsp)");
|
||||
run("setattr -unset mul2dsp", " (if -dsp)");
|
||||
run("select -clear", " (if -dsp)");
|
||||
run("ice40_dsp", " (if -dsp)");
|
||||
run("chtype -set $mul t:$__soft_mul", "(if -dsp)");
|
||||
}
|
||||
run("alumacc");
|
||||
run("opt");
|
||||
|
||||
@@ -346,9 +346,11 @@ struct SynthXilinxPass : public ScriptPass
|
||||
"-D DSP_A_MINWIDTH=2 -D DSP_B_MINWIDTH=2 " // Blocks Nx1 multipliers
|
||||
"-D DSP_Y_MINWIDTH=9 " // UG901 suggests small multiplies are those 4x4 and smaller
|
||||
"-D DSP_SIGNEDONLY=1 -D DSP_NAME=$__MUL25X18");
|
||||
run("opt_expr -fine a:mul2dsp");
|
||||
run("wreduce a:mul2dsp");
|
||||
run("setattr -unset mul2dsp a:mul2dsp");
|
||||
run("select a:mul2dsp");
|
||||
run("opt_expr -fine"):
|
||||
run("wreduce");
|
||||
run("setattr -unset mul2dsp");
|
||||
run("select -clear");
|
||||
run("xilinx_dsp");
|
||||
run("chtype -set $mul t:$__soft_mul");
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user