This patch adds the PseudoCALLReg instruction which allows using an explicit register operand as the destination for the return address.
GCC can successfully parse this form of the call instruction, which would be used for calls to functions which do not use ra as the return address register, such as the __riscv_save libcalls. This patch forms the first part of an implementation of -msave-restore for RISC-V.