How do you plan to solve it?
module dff_async_reset_preset ( input CLK, input RST, input PRE, input D, output reg Q ); always@(posedge CLK or posedge RST or posedge PRE) begin if(RST) Q <= 0; else if(PRE) Q <= 1; else Q <= D; end endmodule