Prev Problem
Next Problem

30. PWM with 4-bit Resolution

Back To All Submissions
Previous Submission
Next Submission

Solving Approach

How do you plan to solve it?

 

 

Code

module pwm4_basic (
    input wire clk,
    input wire rst,
    input wire [3:0] duty,
    output reg pwm_out
);

reg [3:0] cnt;

always @(posedge clk) begin
    if ( rst == 1'b1 ) begin
        cnt <= 4'd0;
        pwm_out <= 1'b0;
    end else begin
        cnt <= cnt + 4'd1;
        pwm_out <= cnt < duty;
    end
end

endmodule

 

Was this helpful?
Upvote
Downvote