Re: [PATCH v5 0/4] Improve pwm-ir-tx precision

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sat, Nov 18, 2023 at 04:16:16PM +0000, Sean Young wrote:
> The pwm-ir-tx driver has to turn the pwm signal on and off, and suffers
> from delays as this is done in process context. Make this work in atomic
> context.

Hi Uwe,

Do you have any comments on this series?

I hope you don't dislike the pwm_apply_atomic()/pwm_apply_cansleep(), I am
not wedded to this name, it's just me reading the room and thinking that
would be the most acceptable to everyone - I may have misread this.

Thank you for any feedback

Sean

> 
> changes:
> 
> v5:
>  - Use dev_err_probe() as Uwe suggested
>  - rebase
> 
> v4:
>  - Split out the pwm_apply_state() rename into seperate commit
>  - Atomic pwm function is called pwm_apply_atomic() and sleeping
>    counterpart pwm_apply_cansleep()
>  - Fix commit messages
> 
> v3:
>  - Renamed pwm_apply_state() to pwm_apply_cansleep()
>  - Moved pwm atomic to struct pwm_chip
>  - Fixed pwm docs
>  - Other minor code review comments
> 
> v2:
>  - Simplified the pwm ir tx based on Ivaylo Dimitrov suggestions
>  - Renamed pwm_can_sleep() to pwm_is_atomic
>  - Fix sleeping issue in pwm-bcm2835 (clk_get_rate() can sleep)
>  - use non_block_start() in pwm to check atomic-ness
> 
> 
> Sean Young (4):
>   pwm: rename pwm_apply_state() to pwm_apply_cansleep()
>   pwm: make it possible to apply pwm changes in atomic context
>   pwm: bcm2835: allow pwm driver to be used in atomic context
>   media: pwm-ir-tx: trigger edges from hrtimer interrupt context
> 
>  Documentation/driver-api/pwm.rst              | 17 +++-
>  .../gpu/drm/i915/display/intel_backlight.c    |  6 +-
>  drivers/gpu/drm/solomon/ssd130x.c             |  2 +-
>  drivers/hwmon/pwm-fan.c                       |  8 +-
>  drivers/input/misc/da7280.c                   |  4 +-
>  drivers/input/misc/pwm-beeper.c               |  4 +-
>  drivers/input/misc/pwm-vibra.c                |  8 +-
>  drivers/leds/leds-pwm.c                       |  2 +-
>  drivers/leds/rgb/leds-pwm-multicolor.c        |  4 +-
>  drivers/media/rc/pwm-ir-tx.c                  | 83 +++++++++++++++++--
>  drivers/platform/x86/lenovo-yogabook.c        |  2 +-
>  drivers/pwm/core.c                            | 75 +++++++++++++----
>  drivers/pwm/pwm-bcm2835.c                     | 31 ++++---
>  drivers/pwm/pwm-renesas-tpu.c                 |  1 -
>  drivers/pwm/pwm-twl-led.c                     |  2 +-
>  drivers/pwm/pwm-vt8500.c                      |  2 +-
>  drivers/pwm/sysfs.c                           | 10 +--
>  drivers/regulator/pwm-regulator.c             |  4 +-
>  drivers/video/backlight/lm3630a_bl.c          |  2 +-
>  drivers/video/backlight/lp855x_bl.c           |  2 +-
>  drivers/video/backlight/pwm_bl.c              | 12 +--
>  drivers/video/fbdev/ssd1307fb.c               |  2 +-
>  include/linux/pwm.h                           | 57 +++++++++----
>  23 files changed, 248 insertions(+), 92 deletions(-)
> 
> -- 
> 2.42.1
> 




[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux