1. 27 8月, 2013 26 次提交
    • R
      leds-pca963x: Fix device tree parsing · 8a6acd64
      Ricardo Ribalda Delgado 提交于
      A malformed device tree could lead into a segmentation fault if the reg
      value of a led is bigger than the number of leds.
      
      A valid device tree could have only information about the last led of the
      chip. Fix the device tree parsing to handle those cases.
      Signed-off-by: NRicardo Ribalda Delgado <ricardo.ribalda@gmail.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      8a6acd64
    • R
      leds-pca9633: Rename to leds-pca963x · 56a1740c
      Ricardo Ribalda Delgado 提交于
      The driver now supports the chips pca9633 and pca9634, therefore we
      rename the files to more generic and meaningul names
      Signed-off-by: NRicardo Ribalda Delgado <ricardo.ribalda@gmail.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      56a1740c
    • R
      leds-pca9633: Add mutex to the ledout register · a7d0e988
      Ricardo Ribalda Delgado 提交于
      To update an LED a register has to be read, updated and writen. If
      another LED whas been updated at the same time, this could lead into
      wrong updates.
      
      This patch adds a common mutex to all the leds of the same chip to
      protect the ledout register.
      Signed-off-by: NRicardo Ribalda Delgado <ricardo.ribalda@gmail.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      a7d0e988
    • R
      leds-pca9633: Unique naming of the LEDs · a5cd98b7
      Ricardo Ribalda Delgado 提交于
      If there is more than one pca963x chips on the system and there are
      some LEDs without platform_data names, the driver wont be able to
      provide unique naming to them.
      
      This will cause led_class_dev_register to fail, unregistering all the
      LEDs of the chip.
      
      This patch adds the i2c address to the name of the unnamed LEDs, making
      them unique.
      
      [  555.346827] ------------[ cut here ]------------
      [  555.346844] WARNING: at /build/linux-voe0Su/linux-3.9.8/fs/sysfs/dir.c:536 sysfs_add_one+0x8b/0x9d()
      [  555.346847] Hardware name: QT5022
      [  555.346850] sysfs: cannot create duplicate filename '/class/leds/pca9633:6'
      [  555.346853] Modules linked in: qt5038_platform(O+) leds_pca9633(O) hid_generic ledtrig_default_on rfcomm bnep bluetooth binfmt_misc nfsd auth_rpcgss nfs_acl nfs lockd dns_resolver fscache sunrpc nls_utf8 nls_cp437 vfat fat loop fuse joydev hid_multitouch usbhid hid acpi_cpufreq mperf kvm_amd kvm evdev pn533 nfc arc4 microcode pcspkr efivars k10temp ath9k ath9k_common ath9k_hw ath fglrx(PO) mac80211 cfg80211 video rfkill processor thermal_sys sp5100_tco button i2c_piix4 ext4 crc16 jbd2 mbcache sg sd_mod crc_t10dif ahci libahci igb i2c_algo_bit i2c_core dca ptp pps_core ehci_pci ohci_hcd ehci_hcd libata usbcore usb_common scsi_mod [last unloaded: leds_pca963x]
      [  555.346940] Pid: 4766, comm: insmod Tainted: P        W  O 3.9-1-amd64 #1 Debian 3.9.8-1
      [  555.346943] Call Trace:
      [  555.346956]  [<ffffffff8103d153>] ? warn_slowpath_common+0x76/0x8c
      [  555.346962]  [<ffffffff8103d202>] ? warn_slowpath_fmt+0x47/0x49
      [  555.346968]  [<ffffffff8116005d>] ? sysfs_pathname+0x3b/0x41
      [  555.346973]  [<ffffffff81160767>] ? sysfs_add_one+0x8b/0x9d
      [  555.346978]  [<ffffffff811610a4>] ? sysfs_do_create_link_sd+0xe8/0x174
      [  555.346985]  [<ffffffff81279250>] ? device_add+0x243/0x5ab
      [  555.346991]  [<ffffffff81060a16>] ? complete_all+0x31/0x40
      [  555.346998]  [<ffffffff8104991a>] ? init_timer_key+0xc/0x56
      [  555.347004]  [<ffffffff8127964c>] ? device_create_vargs+0x82/0xb6
      [  555.347009]  [<ffffffff812796af>] ? device_create+0x2f/0x31
      [  555.347014]  [<ffffffff81060add>] ? should_resched+0x5/0x23
      [  555.347021]  [<ffffffff812a3a92>] ? led_classdev_register+0x24/0x103
      [  555.347028]  [<ffffffffa09d01c0>] ? pca9633_probe+0x173/0x239 [leds_pca9633]
      [  555.347035]  [<ffffffff8127b504>] ? __driver_attach+0x73/0x73
      [  555.347049]  [<ffffffffa009dfc9>] ? i2c_device_probe+0x63/0x88 [i2c_core]
      [  555.347057]  [<ffffffff8127b373>] ? driver_probe_device+0x92/0x1b0
      [  555.347064]  [<ffffffff81279c5c>] ? bus_for_each_drv+0x43/0x7d
      [  555.347070]  [<ffffffff8127b2af>] ? device_attach+0x68/0x83
      [  555.347078]  [<ffffffff8127a990>] ? bus_probe_device+0x25/0x8d
      [  555.347083]  [<ffffffff812793f7>] ? device_add+0x3ea/0x5ab
      [  555.347088]  [<ffffffff81060a16>] ? complete_all+0x31/0x40
      [  555.347094]  [<ffffffff8104991a>] ? init_timer_key+0xc/0x56
      [  555.347104]  [<ffffffffa009d3a1>] ? i2c_new_device+0x10d/0x179 [i2c_core]
      [  555.347112]  [<ffffffffa008f036>] ? qt5038_init+0x36/0x1000 [qt5038_platform]
      [  555.347119]  [<ffffffffa008f000>] ? 0xffffffffa008efff
      [  555.347125]  [<ffffffff8100209e>] ? do_one_initcall+0x74/0x128
      [  555.347131]  [<ffffffffa008f000>] ? 0xffffffffa008efff
      [  555.347137]  [<ffffffff810836f5>] ? load_module+0x1af7/0x1dfc
      [  555.347144]  [<ffffffff810801c5>] ? free_notes_attrs+0x3c/0x3c
      [  555.347150]  [<ffffffff81083a98>] ? sys_init_module+0x9e/0xab
      [  555.347157]  [<ffffffff8138be29>] ? system_call_fastpath+0x16/0x1b
      [  555.347161] ---[ end trace ad00b85794e0de4d ]---
      [  555.347448] leds-pca9633: probe of 0-006b failed with error -17
      Signed-off-by: NRicardo Ribalda Delgado <ricardo.ribalda@gmail.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      a5cd98b7
    • R
      leds-pca9633: Add support for PCA9634 · af67384f
      Ricardo Ribalda Delgado 提交于
      Add support for PCA9634 chip, which belongs to the same family as the
      9633 but with support for 8 outputs instead of 4.
      Signed-off-by: NRicardo Ribalda Delgado <ricardo.ribalda@gmail.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      af67384f
    • M
      leds: lp5562: use LP55xx common macros for device attributes · daa124b1
      Milo Kim 提交于
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      daa124b1
    • M
      Documentation: leds-lp5521,lp5523: update device attribute information · 863724a6
      Milo Kim 提交于
      Now, all legacy application interfaces are restored.
      Each driver documentation is updated.
      
      Cc: Pali Rohár <pali.rohar@gmail.com>
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      863724a6
    • M
      leds: lp5523: remove unnecessary writing commands · 2f733cad
      Milo Kim 提交于
      This patch reduces the number of programming commands.
      
      (Count of sending commands)
      Old code: 32 + program size (32 counts for clearing program memory)
      New code: 32
      
      Pattern buffer is initialized to 0 in this function.
      Just update new program data and remaining buffers are filled with 0.
      So it's needless to clear whole area.
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      2f733cad
    • M
      leds: lp5523: restore legacy device attributes · 45e611bf
      Milo Kim 提交于
      git commit db6eaf83
      (leds-lp5523: use generic firmware interface) causes an application conflict.
      This interface should be maintained for compatibility.
      
      Restored device attributes are 'engineN_mode', 'engineN_load' and
      'engineN_leds'. (N = 1, 2 or 3)
      A 'selftest' attribute macro is replaced with LP55xx common macro.
      Those are accessed when a LED pattern is run by an application.
      
      Use a mutex in lp5523_update_program_memory()
      : This function is called when an user-application writes a 'engineN_load' file
      or pattern data is loaded from generic firmware interface.
      So, writing program memory should be protected.
      If an error occurs on accessing this area, just it returns as -EINVAL quickly.
      This error code is exact same as old driver function, lp5523_do_store_load()
      because it should be kept for an user-application compatibility.
      Even the driver is changed, we can use the application without re-compiling
      sources.
      Reported-by: NPali Rohár <pali.rohar@gmail.com>
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      45e611bf
    • M
      leds: lp5523: LED MUX configuration on initializing · 22460438
      Milo Kim 提交于
      LED MUX start and stop address should be updated in the program memory
      on LP5523 initialization.
      LED pattern doesn't work without additional MUX address configuration.
      This handling is done by new function, lp5523_init_program_engine().
      Eventually, it's called during device initialization, lp5523_post_init_device().
      
      This is a conflict after git commit 632418bf
      (leds-lp5523: clean up lp5523_configure()).
      So it should be fixed.
      
      Cc: Pali Rohár <pali.rohar@gmail.com>
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      22460438
    • M
      leds: lp5523: make separate API for loading engine · b9e1730b
      Milo Kim 提交于
      lp5523_load_engine()
        It is called whenever the operation mode is changed to 'load'.
        It is used for simple operation mode change.
        It will be used when engine mode and LED selection is updated in later patch.
      
      lp5523_load_engine_and_select_page()
        Change the operation mode to 'load' and select program page number.
        This is used for programming a LED pattern at a time.
        So load_engine() is replaced with new API, load_engine_and_select_page()
        in lp5523_firmware_loaded().
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      b9e1730b
    • M
      leds: lp5521: remove unnecessary writing commands · 1eca0b3a
      Milo Kim 提交于
      This patch reduces the number of programming commands.
      
      (Count of sending commands)
      Old code: 32 + program size (32 counts for clearing program memory)
      New code: 32
      
      Pattern buffer is initialized to 0 in this function.
      Just update new program data and remaining buffers are filled with 0.
      So it's needless to clear whole area.
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      1eca0b3a
    • M
      leds: lp5521: restore legacy device attributes · c0e5e9b5
      Milo Kim 提交于
      git commit 9ce7cb17
      may cause an application confict, engineN_mode and engineN_load.
      This interface should be maintained for compatibility.
      
      Restored device attributes are 'engineN_mode' and 'engineN_load'.
      A 'selftest' attribute macro is replaced with LP55xx common macro.
      
      Use a mutex in lp5521_update_program_memory()
      : This function is called when an user-application writes a 'engineN_load' file
      or pattern data is loaded from generic firmware interface.
      So, writing program memory should be protected.
      If an error occurs on accessing this area, just it returns as -EINVAL quickly.
      This error code is exact same as old driver function, lp5521_do_store_load()
      because it should be kept for an user-application compatibility.
      Even the driver is changed, we can use the application without re-compiling
      sources.
      
      'led_pattern' attribute is not included
      : engineN_mode and _load were created for custom user-application.
      'led_pattern' is an exception. I added this attribute not for custom application
      but for simple test. Now it is used only in LP5562 driver, not LP5521.
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      c0e5e9b5
    • M
      leds: lp55xx: add common macros for device attributes · 36030978
      Milo Kim 提交于
      This patch provides common macros for LP5521 and LP5523 device attributes and
      functions.
      
      (Device attributes)
      LP5521: 'mode', 'load' and 'selftest'
      LP5523: 'mode', 'load', 'leds' and 'selftest'
      
      (Permissions)
      mode: R/W
      load: Write-only
      leds: R/W
      selftest: Read-only
      
      Couple of lines are duplicate, so use these macros for adding device attributes
      in LP5521 and LP5523 drivers.
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      36030978
    • M
      leds: lp55xx: add common data structure for program · 6841a91d
      Milo Kim 提交于
      LP55xx family devices have internal three program engines which are used for
      loading LED patterns. To maintain legacy device attributes, specific data
      structure is used, 'mode' and 'led_mux'. The mode is used for showing/storing
      current engine mode such like disabled, load and run. Then led_mux is used for
      showing/storing current output LED selection.
      
      This is only for LP5523/55231.
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      6841a91d
    • S
      Documentation: leds: Fix a typo · e5862b9a
      Sachin Kamat 提交于
      __initdata should be placed between the variable name and equal
      sign for the variable to be placed in the intended section.
      Fix the example.
      Signed-off-by: NSachin Kamat <sachin.kamat@linaro.org>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      e5862b9a
    • S
      leds: ss4200: Fix incorrect placement of __initdata · b06cf2d7
      Sachin Kamat 提交于
      __initdata should be placed between the variable name and equal
      sign for the variable to be placed in the intended section.
      Signed-off-by: NSachin Kamat <sachin.kamat@linaro.org>
      Cc: Dave Hansen <dave@sr71.net>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      b06cf2d7
    • S
      leds: clevo-mail: Fix incorrect placement of __initdata · 939086ea
      Sachin Kamat 提交于
      __initdata should be placed between the variable name and equal
      sign for the variable to be placed in the intended section.
      Signed-off-by: NSachin Kamat <sachin.kamat@linaro.org>
      Cc: Márton Németh <nm127@freemail.hu>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      939086ea
    • S
      leds: leds-netxbig: depends on ARCH_KIRKWOOD · d6d240bf
      Simon Guinot 提交于
      With the DT conversion, the board Kconfig symbols MACH_ are going to be
      removed. In order to prepare this removal, this patch replaces alls the
      machines dependencies for leds-netxbig by ARCH_KIRKWOOD.
      Signed-off-by: NSimon Guinot <simon.guinot@sequanux.org>
      Acked-by: NJason Cooper <jason@lakedaemon.net>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      d6d240bf
    • S
      leds: leds-ns2: depends on ARCH_KIRKWOOD · d6626d10
      Simon Guinot 提交于
      With the DT conversion, the board Kconfig symbols MACH_ are going to be
      removed. In order to prepare this removal, this patch replaces alls the
      machines dependencies for leds-ns2 by ARCH_KIRKWOOD.
      Signed-off-by: NSimon Guinot <simon.guinot@sequanux.org>
      Acked-by: NJason Cooper <jason@lakedaemon.net>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      d6626d10
    • A
      leds: leds-lp3944, fix "sparse" warning "mixing different enum types" · 29ab311c
      Antonio Ospite 提交于
      Fix a warning from "sparse":
      
      drivers/leds/leds-lp3944.c:292:23: warning: mixing different enum types
      drivers/leds/leds-lp3944.c:292:23:     int enum led_brightness  versus
      drivers/leds/leds-lp3944.c:292:23:     int enum lp3944_status
      
      Keeping track of LP3944_LED_STATUS_OFF and LP3944_LED_STATUS_ON only in
      lp3944_led_set_brightness() is OK, as the handling of DIM (blinking)
      mode[s] is in lp3944_led_set_blink().
      Reported-by: NDan Carpenter <dan.carpenter@oracle.com>
      Signed-off-by: NAntonio Ospite <ospite@studenti.unina.it>
      Reviewed-by: NJingoo Han <jg1.han@samsung.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      29ab311c
    • J
      leds: leds-ss4200: Staticize nasgpio_led_get_attr() · 2e87c092
      Jingoo Han 提交于
      nasgpio_led_get_attr() is used only in this file.
      Fix the following sparse warning:
      
      drivers/leds/leds-ss4200.c:200:5: warning: symbol 'nasgpio_led_get_attr' was not declared. Should it be static?
      Signed-off-by: NJingoo Han <jg1.han@samsung.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      2e87c092
    • J
      leds: use dev_get_platdata() · 87aae1ea
      Jingoo Han 提交于
      Use the wrapper function for retrieving the platform data instead of
      accessing dev->platform_data directly.
      Signed-off-by: NJingoo Han <jg1.han@samsung.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      87aae1ea
    • M
      leds: pca9633: Add hardware blink support · 8465b018
      Mark A. Greer 提交于
      Add hardware blinking support to the pca9633 driver.
      
      NOTE: Hardware blinking violates the leds infrastructure
      driver interface since the hardware only supports
      blinking all LEDs with the same delay_on/delay_off
      rates.  That is, only the LEDs that are set to blink
      will actually blink but all LEDs that are set to blink
      will blink in identical fashion.  The delay_on/delay_off
      values of the last LED that is set to blink will be used
      for all of the blinking LEDs.  If the hardware doesn't
      support the requested blinking pattern, a default of
      500ms on and off will be used.
      
      Hardware blinking is disabled by default but can be enabled
      by setting the 'blink_type' member in the platform_data
      struct to 'PCA9633_HW_BLINK' or by adding the 'nxp,hw-blink'
      property to the DTS.
      
      (fengguang.wu@intel.com: Removes unneeded semicolon.)
      Signed-off-by: NMark A. Greer <mgreer@animalcreek.com>
      Reported-by: NFengguang Wu <fengguang.wu@intel.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      8465b018
    • K
      leds: support new LP8501 device - another LP55xx common · 33b3a561
      Kim, Milo 提交于
      LP8501 can drive up to 9 channels like LP5523.
      LEDs can be controlled directly via the I2C and programmable engines are
      supported.
      
      LP55xx common driver
       LP8501 is one of LP55xx family device, so LP55xx common code are used.
       Chip specific data is defined in the structure, 'lp55xx_device_config'.
      
      Differences between LP8501 and LP5523
       Different register layout for LED output control and others.
       LP8501 specific feature for separate output power selection.
       LP8501 doesn't support external clock detection.
       Different programming engine data.
      
      LP8501 specific feature - output power selection
       Output channels are selected by power selection - Vout or Vdd.
       Separate power for VDD1-6 and VDD7-9 are available.
       It is configurable in the platform data.
       To support this feature, LP55xx DT structure and header are changed.
       Device tree binding is updated as well.
      
      LED pattern data
       Example pattern data is updated in the driver documentation.
      Signed-off-by: NMilo Kim <milo.kim@ti.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      33b3a561
    • T
      leds: Add device tree binding for pca9633 · 81d22878
      Tony Lindgren 提交于
      Similar to tca6507, we can just parse the standard LED
      properties for pca9633.
      
      Tested on a pca9632, which is compatible with pca9633.
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NBryan Wu <cooloney@gmail.com>
      81d22878
  2. 26 8月, 2013 5 次提交
  3. 25 8月, 2013 8 次提交
  4. 24 8月, 2013 1 次提交