Commit 5e80416e authored by Andrew Leech's avatar Andrew Leech Committed by Damien George

nrf/modules/machine/soft_pwm: Ensure duty_width is always valid.

Signed-off-by: default avatarAndrew Leech <andrew@alelec.net>
parent 62e0fa04
...@@ -199,6 +199,8 @@ static void machine_soft_pwm_start(machine_pwm_obj_t *self) { ...@@ -199,6 +199,8 @@ static void machine_soft_pwm_start(machine_pwm_obj_t *self) {
duty_width = self->duty * DUTY_FULL_SCALE / 65536; duty_width = self->duty * DUTY_FULL_SCALE / 65536;
} else if (self->duty_mode == DUTY_NS) { } else if (self->duty_mode == DUTY_NS) {
duty_width = (uint64_t)self->duty * self->freq * DUTY_FULL_SCALE / 1000000000ULL; duty_width = (uint64_t)self->duty * self->freq * DUTY_FULL_SCALE / 1000000000ULL;
} else {
mp_raise_ValueError(MP_ERROR_TEXT("invalid duty mode"));
} }
pwm_set_duty_cycle(self->pwm_pin, duty_width); pwm_set_duty_cycle(self->pwm_pin, duty_width);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment