Lines Matching +full:pwm +full:- +full:off +full:- +full:delay +full:- +full:ms
1 // SPDX-License-Identifier: GPL-2.0-only
5 * Copyright (C) 2007-2009 Nokia Corporation
18 #include <linux/delay.h>
45 #define LM8323_CMD_PWM_WRITE 0x95 /* Write PWM script. */
46 #define LM8323_CMD_START_PWM 0x96 /* Start PWM engine. */
47 #define LM8323_CMD_STOP_PWM 0x97 /* Stop PWM engine. */
87 /* Commands for PWM engine; feed in with PWM_WRITE. */
88 /* Load ramp counter from duty cycle field (range 0 - 0xff). */
126 /* pwm lock */
147 struct lm8323_pwm pwm[LM8323_NUM_PWMS]; member
151 #define dev_to_lm8323(d) container_of(d, struct lm8323_chip, client->dev)
171 dev_err(&lm->client->dev, "tried to send %d bytes\n", len); in lm8323_write()
185 ret = i2c_master_send(lm->client, data, len); in lm8323_write()
186 if (unlikely(ret == -EREMOTEIO)) in lm8323_write()
187 ret = i2c_master_send(lm->client, data, len); in lm8323_write()
189 dev_err(&lm->client->dev, "sent %d bytes of %d total\n", in lm8323_write()
207 ret = i2c_master_send(lm->client, &cmd, 1); in lm8323_read()
208 if (unlikely(ret == -EREMOTEIO)) in lm8323_read()
209 ret = i2c_master_send(lm->client, &cmd, 1); in lm8323_read()
211 dev_err(&lm->client->dev, "sending read cmd 0x%02x failed\n", in lm8323_read()
216 ret = i2c_master_recv(lm->client, buf, len); in lm8323_read()
218 dev_err(&lm->client->dev, "wanted %d bytes, got %d\n", in lm8323_read()
233 * The signals are AT-style: the low 7 bits are the keycode, and the top
250 int old_keys_down = lm->keys_down; in process_keys()
261 dev_err(&lm->client->dev, "Failed reading fifo \n"); in process_keys()
269 unsigned short keycode = lm->keymap[key]; in process_keys()
271 dev_vdbg(&lm->client->dev, "key 0x%02x %s\n", in process_keys()
274 if (lm->kp_enabled) { in process_keys()
275 input_event(lm->idev, EV_MSC, MSC_SCAN, key); in process_keys()
276 input_report_key(lm->idev, keycode, isdown); in process_keys()
277 input_sync(lm->idev); in process_keys()
281 lm->keys_down++; in process_keys()
283 lm->keys_down--; in process_keys()
291 if (!old_keys_down && lm->keys_down) in process_keys()
293 if (old_keys_down && !lm->keys_down) in process_keys()
294 lm8323_set_active_time(lm, lm->active_time); in process_keys()
303 dev_vdbg(&lm->client->dev, "fifo overflow!\n"); in lm8323_process_error()
305 dev_vdbg(&lm->client->dev, in lm8323_process_error()
308 dev_vdbg(&lm->client->dev, in lm8323_process_error()
311 dev_vdbg(&lm->client->dev, "bad command parameter\n"); in lm8323_process_error()
323 int keysize = (lm->size_x << 4) | lm->size_y; in lm8323_configure()
325 int debounce = lm->debounce_time >> 2; in lm8323_configure()
326 int active = lm->active_time >> 2; in lm8323_configure()
330 * a close-run thing, give ourselves a 12ms buffer. in lm8323_configure()
338 lm8323_set_active_time(lm, lm->active_time); in lm8323_configure()
351 static void pwm_done(struct lm8323_pwm *pwm) in pwm_done() argument
353 mutex_lock(&pwm->lock); in pwm_done()
354 pwm->running = false; in pwm_done()
355 if (pwm->desired_brightness != pwm->brightness) in pwm_done()
356 schedule_work(&pwm->work); in pwm_done()
357 mutex_unlock(&pwm->lock); in pwm_done()
370 mutex_lock(&lm->lock); in lm8323_irq()
377 dev_vdbg(&lm->client->dev, "rotator fired\n"); in lm8323_irq()
380 dev_vdbg(&lm->client->dev, "error!\n"); in lm8323_irq()
384 dev_err(&lm->client->dev, "chip lost config; " in lm8323_irq()
390 dev_vdbg(&lm->client->dev, in lm8323_irq()
391 "pwm%d engine completed\n", i); in lm8323_irq()
392 pwm_done(&lm->pwm[i]); in lm8323_irq()
397 mutex_unlock(&lm->lock); in lm8323_irq()
411 return -EIO; in lm8323_read_id()
416 static void lm8323_write_pwm_one(struct lm8323_pwm *pwm, int pos, u16 cmd) in lm8323_write_pwm_one() argument
418 lm8323_write(pwm->chip, 4, LM8323_CMD_PWM_WRITE, (pos << 2) | pwm->id, in lm8323_write_pwm_one()
423 * Write a script into a given PWM engine, concluding with PWM_END.
426 * will be kept running at the final PWM level indefinitely.
428 static void lm8323_write_pwm(struct lm8323_pwm *pwm, int kill, in lm8323_write_pwm() argument
434 lm8323_write_pwm_one(pwm, i, cmds[i]); in lm8323_write_pwm()
436 lm8323_write_pwm_one(pwm, i++, PWM_END(kill)); in lm8323_write_pwm()
437 lm8323_write(pwm->chip, 2, LM8323_CMD_START_PWM, pwm->id); in lm8323_write_pwm()
438 pwm->running = true; in lm8323_write_pwm()
443 struct lm8323_pwm *pwm = work_to_pwm(work); in lm8323_pwm_work() local
448 mutex_lock(&pwm->lock); in lm8323_pwm_work()
453 * case we will be called again when the previous PWM script in lm8323_pwm_work()
456 if (pwm->running || pwm->desired_brightness == pwm->brightness) in lm8323_pwm_work()
459 kill = (pwm->desired_brightness == 0); in lm8323_pwm_work()
460 up = (pwm->desired_brightness > pwm->brightness); in lm8323_pwm_work()
461 steps = abs(pwm->desired_brightness - pwm->brightness); in lm8323_pwm_work()
464 * Convert time (in ms) into a divisor (512 or 16 on a refclk of in lm8323_pwm_work()
467 if ((pwm->fade_time / steps) > (32768 / 512)) { in lm8323_pwm_work()
475 perstep = (hz * pwm->fade_time) / (steps * 1000); in lm8323_pwm_work()
487 steps -= s; in lm8323_pwm_work()
490 lm8323_write_pwm(pwm, kill, num_cmds, pwm_cmds); in lm8323_pwm_work()
491 pwm->brightness = pwm->desired_brightness; in lm8323_pwm_work()
494 mutex_unlock(&pwm->lock); in lm8323_pwm_work()
500 struct lm8323_pwm *pwm = cdev_to_pwm(led_cdev); in lm8323_pwm_set_brightness() local
501 struct lm8323_chip *lm = pwm->chip; in lm8323_pwm_set_brightness()
503 mutex_lock(&pwm->lock); in lm8323_pwm_set_brightness()
504 pwm->desired_brightness = brightness; in lm8323_pwm_set_brightness()
505 mutex_unlock(&pwm->lock); in lm8323_pwm_set_brightness()
508 schedule_work(&pwm->work); in lm8323_pwm_set_brightness()
511 * Schedule PWM work as usual unless we are going into suspend in lm8323_pwm_set_brightness()
513 mutex_lock(&lm->lock); in lm8323_pwm_set_brightness()
514 if (likely(!lm->pm_suspend)) in lm8323_pwm_set_brightness()
515 schedule_work(&pwm->work); in lm8323_pwm_set_brightness()
517 lm8323_pwm_work(&pwm->work); in lm8323_pwm_set_brightness()
518 mutex_unlock(&lm->lock); in lm8323_pwm_set_brightness()
526 struct lm8323_pwm *pwm = cdev_to_pwm(led_cdev); in lm8323_pwm_show_time() local
528 return sprintf(buf, "%d\n", pwm->fade_time); in lm8323_pwm_show_time()
535 struct lm8323_pwm *pwm = cdev_to_pwm(led_cdev); in lm8323_pwm_store_time() local
543 pwm->fade_time = time; in lm8323_pwm_store_time()
558 struct lm8323_pwm *pwm; in init_pwm() local
562 pwm = &lm->pwm[id - 1]; in init_pwm()
564 pwm->id = id; in init_pwm()
565 pwm->fade_time = 0; in init_pwm()
566 pwm->brightness = 0; in init_pwm()
567 pwm->desired_brightness = 0; in init_pwm()
568 pwm->running = false; in init_pwm()
569 pwm->enabled = false; in init_pwm()
570 INIT_WORK(&pwm->work, lm8323_pwm_work); in init_pwm()
571 mutex_init(&pwm->lock); in init_pwm()
572 pwm->chip = lm; in init_pwm()
575 pwm->cdev.name = name; in init_pwm()
576 pwm->cdev.brightness_set = lm8323_pwm_set_brightness; in init_pwm()
577 pwm->cdev.groups = lm8323_pwm_groups; in init_pwm()
578 if (led_classdev_register(dev, &pwm->cdev) < 0) { in init_pwm()
579 dev_err(dev, "couldn't register PWM %d\n", id); in init_pwm()
580 return -1; in init_pwm()
582 pwm->enabled = true; in init_pwm()
595 return sprintf(buf, "%u\n", !lm->kp_enabled); in lm8323_show_disable()
610 mutex_lock(&lm->lock); in lm8323_set_disable()
611 lm->kp_enabled = !i; in lm8323_set_disable()
612 mutex_unlock(&lm->lock); in lm8323_set_disable()
621 struct lm8323_platform_data *pdata = dev_get_platdata(&client->dev); in lm8323_probe()
624 int pwm; in lm8323_probe() local
629 if (!pdata || !pdata->size_x || !pdata->size_y) { in lm8323_probe()
630 dev_err(&client->dev, "missing platform_data\n"); in lm8323_probe()
631 return -EINVAL; in lm8323_probe()
634 if (pdata->size_x > 8) { in lm8323_probe()
635 dev_err(&client->dev, "invalid x size %d specified\n", in lm8323_probe()
636 pdata->size_x); in lm8323_probe()
637 return -EINVAL; in lm8323_probe()
640 if (pdata->size_y > 12) { in lm8323_probe()
641 dev_err(&client->dev, "invalid y size %d specified\n", in lm8323_probe()
642 pdata->size_y); in lm8323_probe()
643 return -EINVAL; in lm8323_probe()
649 err = -ENOMEM; in lm8323_probe()
653 lm->client = client; in lm8323_probe()
654 lm->idev = idev; in lm8323_probe()
655 mutex_init(&lm->lock); in lm8323_probe()
657 lm->size_x = pdata->size_x; in lm8323_probe()
658 lm->size_y = pdata->size_y; in lm8323_probe()
659 dev_vdbg(&client->dev, "Keypad size: %d x %d\n", in lm8323_probe()
660 lm->size_x, lm->size_y); in lm8323_probe()
662 lm->debounce_time = pdata->debounce_time; in lm8323_probe()
663 lm->active_time = pdata->active_time; in lm8323_probe()
668 * 100ms until we can configure. */ in lm8323_probe()
675 dev_err(&client->dev, in lm8323_probe()
687 dev_err(&client->dev, "device not found\n"); in lm8323_probe()
688 err = -ENODEV; in lm8323_probe()
692 for (pwm = 0; pwm < LM8323_NUM_PWMS; pwm++) { in lm8323_probe()
693 err = init_pwm(lm, pwm + 1, &client->dev, in lm8323_probe()
694 pdata->pwm_names[pwm]); in lm8323_probe()
699 lm->kp_enabled = true; in lm8323_probe()
700 err = device_create_file(&client->dev, &dev_attr_disable_kp); in lm8323_probe()
704 idev->name = pdata->name ? : "LM8323 keypad"; in lm8323_probe()
705 snprintf(lm->phys, sizeof(lm->phys), in lm8323_probe()
706 "%s/input-kp", dev_name(&client->dev)); in lm8323_probe()
707 idev->phys = lm->phys; in lm8323_probe()
709 idev->evbit[0] = BIT(EV_KEY) | BIT(EV_MSC); in lm8323_probe()
710 __set_bit(MSC_SCAN, idev->mscbit); in lm8323_probe()
712 __set_bit(pdata->keymap[i], idev->keybit); in lm8323_probe()
713 lm->keymap[i] = pdata->keymap[i]; in lm8323_probe()
715 __clear_bit(KEY_RESERVED, idev->keybit); in lm8323_probe()
717 if (pdata->repeat) in lm8323_probe()
718 __set_bit(EV_REP, idev->evbit); in lm8323_probe()
722 dev_dbg(&client->dev, "error registering input device\n"); in lm8323_probe()
726 err = request_threaded_irq(client->irq, NULL, lm8323_irq, in lm8323_probe()
729 dev_err(&client->dev, "could not get IRQ %d\n", client->irq); in lm8323_probe()
735 device_init_wakeup(&client->dev, 1); in lm8323_probe()
736 enable_irq_wake(client->irq); in lm8323_probe()
744 device_remove_file(&client->dev, &dev_attr_disable_kp); in lm8323_probe()
746 while (--pwm >= 0) in lm8323_probe()
747 if (lm->pwm[pwm].enabled) in lm8323_probe()
748 led_classdev_unregister(&lm->pwm[pwm].cdev); in lm8323_probe()
760 disable_irq_wake(client->irq); in lm8323_remove()
761 free_irq(client->irq, lm); in lm8323_remove()
763 input_unregister_device(lm->idev); in lm8323_remove()
765 device_remove_file(&lm->client->dev, &dev_attr_disable_kp); in lm8323_remove()
768 if (lm->pwm[i].enabled) in lm8323_remove()
769 led_classdev_unregister(&lm->pwm[i].cdev); in lm8323_remove()
776 * We don't need to explicitly suspend the chip, as it already switches off
785 irq_set_irq_wake(client->irq, 0); in lm8323_suspend()
786 disable_irq(client->irq); in lm8323_suspend()
788 mutex_lock(&lm->lock); in lm8323_suspend()
789 lm->pm_suspend = true; in lm8323_suspend()
790 mutex_unlock(&lm->lock); in lm8323_suspend()
793 if (lm->pwm[i].enabled) in lm8323_suspend()
794 led_classdev_suspend(&lm->pwm[i].cdev); in lm8323_suspend()
805 mutex_lock(&lm->lock); in lm8323_resume()
806 lm->pm_suspend = false; in lm8323_resume()
807 mutex_unlock(&lm->lock); in lm8323_resume()
810 if (lm->pwm[i].enabled) in lm8323_resume()
811 led_classdev_resume(&lm->pwm[i].cdev); in lm8323_resume()
813 enable_irq(client->irq); in lm8323_resume()
814 irq_set_irq_wake(client->irq, 1); in lm8323_resume()