rL369567 reverted a couple of recent changes made to ARMParallelDSP because of a miscompilation error: PR43073. The issue stemmed from an underlying bug that was caused by adding muls into a reduction before it was proved that they could be executed in parallel with another mul. Most of the changes here are from the previously reverted commits. The additional changes have been made area:
- The Search function now doesn't insert any muls into the Reduction object. That now happens once the search has successfully finished.
- For any muls added into the reduction but that wasn't paired, we accumulate the value as an input into the smlad.