linux/drivers/i2c/busses
Doug Anderson cbfff439c5 i2c: rk3x: Restore clock settings at resume time
Depending on a number of factors including:
- Which exact Rockchip SoC we're working with
- How deep we suspend
- Which i2c port we're on

We might lose the state of the i2c registers at suspend time.
Specifically we've found that on rk3399 the i2c ports that are not in
the PMU power domain lose their state with the current suspend depth
configured by ARM Tursted Firmware.

Note that there are very few actual i2c registers that aren't configured
per transfer anyway so all we actually need to re-configure are the
clock config registers.  We'll just add a call to rk3x_i2c_adapt_div()
at resume time and be done with it.

NOTE: On rk3399 on ports whose power was lost, I put printouts in at
resume time.  I saw things like:
  before: con=0x00010300, div=0x00060006
  after:  con=0x00010200, div=0x00180025

Signed-off-by: Douglas Anderson <dianders@chromium.org>
Reviewed-by: David Wu <david.wu@rock-chips.com>
Tested-by: David Wu <david.wu@rock-chips.com>
[wsa: removed duplicate const]
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
2016-09-08 22:50:33 +02:00
..
i2c-acorn.c
i2c-ali15x3.c
i2c-ali1535.c
i2c-ali1563.c
i2c-amd756-s4882.c
i2c-amd756.c
i2c-amd8111.c
i2c-at91.c i2c: at91: fix support of the "alternative command" feature 2016-08-15 00:55:30 +02:00
i2c-au1550.c
i2c-axxia.c
i2c-bcm2835.c i2c: bcm2835: Don't complain on -EPROBE_DEFER from getting our clock 2016-07-22 09:23:53 +02:00
i2c-bcm-iproc.c i2c: bcm-iproc: Use complete() instead of complete_all() 2016-08-15 00:55:31 +02:00
i2c-bcm-kona.c i2c: bcm-kona: fix inconsistent indenting 2016-08-25 18:52:07 +02:00
i2c-bfin-twi.c
i2c-brcmstb.c i2c: brcmstb: Use complete() instead of complete_all() 2016-08-15 00:55:33 +02:00
i2c-cadence.c i2c: Spelling s/acknowedge/acknowledge/ 2016-09-08 22:22:20 +02:00
i2c-cbus-gpio.c
i2c-cpm.c Merge branch 'i2c/for-4.7' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux 2016-05-19 17:48:12 -07:00
i2c-cros-ec-tunnel.c i2c: cros-ec-tunnel: Fix usage of cros_ec_cmd_xfer() 2016-08-15 00:55:14 +02:00
i2c-davinci.c i2c: davinci: Increase module clock frequency 2015-11-30 15:55:07 +01:00
i2c-designware-baytrail.c i2c: designware-platform: Drop duplicate module information 2016-02-12 20:40:13 +01:00
i2c-designware-core.c i2c: designware: save the preset value of DW_IC_SDA_HOLD 2016-09-08 22:14:36 +02:00
i2c-designware-core.h i2c: designware-pci: Make bus number allocation robust 2016-06-19 19:34:16 +02:00
i2c-designware-pcidrv.c i2c: designware-pci: clarify a comment for Merrifield 2016-07-06 00:42:17 +09:00
i2c-designware-platdrv.c i2c: designware: Add device HID for future AMD I2C controller 2016-03-10 21:34:47 +01:00
i2c-digicolor.c
i2c-diolan-u2c.c
i2c-dln2.c i2c: dln2: Pass forward ACPI companion 2016-04-24 22:22:53 +02:00
i2c-efm32.c i2c: efm32: fix a failure path in efm32_i2c_probe() 2016-07-19 06:23:48 +02:00
i2c-eg20t.c i2c: eg20t: set i2c_adapter->dev.of_node 2015-12-03 22:11:46 +01:00
i2c-elektor.c i2c: elektor: Utilize the module_isa_driver macro 2016-06-19 19:45:43 +02:00
i2c-emev2.c i2c: emev2: add slave support 2015-12-05 19:55:36 +01:00
i2c-exynos5.c Merge branch 'i2c/for-4.7' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux 2016-05-19 17:48:12 -07:00
i2c-gpio.c
i2c-highlander.c
i2c-hix5hd2.c
i2c-hydra.c
i2c-i801.c i2c: i801: use IS_ENABLED() instead of checking for built-in or module 2016-07-26 08:44:56 +02:00
i2c-ibm_iic.c i2c: ibm_iic: use new 8 bit address helper function 2016-04-11 18:54:59 +02:00
i2c-ibm_iic.h
i2c-img-scb.c i2c: img-scb: use new 8 bit address helper function 2016-04-11 18:54:59 +02:00
i2c-imx.c i2c: imx: reduce load by using usleep_range instead of udelay 2016-04-26 23:34:09 +02:00
i2c-iop3xx.c i2c: iop3xx: use new 8 bit address helper function 2016-04-11 18:54:59 +02:00
i2c-iop3xx.h
i2c-isch.c
i2c-ismt.c i2c: ismt: Add Intel DNV PCI ID 2016-04-12 23:44:16 +02:00
i2c-jz4780.c i2c: jz4780: drop superfluous init 2016-06-13 22:32:09 +02:00
i2c-kempld.c
i2c-lpc2k.c i2c: lpc2k: use new 8 bit address helper function 2016-04-11 18:54:59 +02:00
i2c-meson.c i2c: meson: Use complete() instead of complete_all() 2016-08-15 00:55:34 +02:00
i2c-mpc.c
i2c-mt65xx.c i2c: mt65xx: use new 8 bit address helper function 2016-04-11 18:54:59 +02:00
i2c-mv64xxx.c i2c: mv64xxx: remove CONFIG_HAVE_CLK conditionals 2016-04-27 19:03:15 +02:00
i2c-mxs.c
i2c-nforce2-s4985.c
i2c-nforce2.c i2c: nforce2: Use IS_ENABLED() instead of checking for built-in or module 2016-04-26 23:36:47 +02:00
i2c-nomadik.c
i2c-ocores.c i2c: ocores: add missed clk_disable_unprepare() on failure paths 2016-08-15 00:55:29 +02:00
i2c-octeon.c i2c: octeon: Avoid printk after too long SMBUS message 2016-06-09 22:07:57 +02:00
i2c-omap.c i2c: omap: drop the lock hard irq context 2016-04-24 22:33:09 +02:00
i2c-opal.c powerpc/opal: Add inline function to get rc from an ASYNC_COMP opal_msg 2016-06-29 17:33:18 +10:00
i2c-parport-light.c
i2c-parport.c
i2c-parport.h
i2c-pasemi.c
i2c-pca-isa.c i2c: pca-isa: Utilize the module_isa_driver macro 2016-06-19 19:49:29 +02:00
i2c-pca-platform.c
i2c-piix4.c i2c: piix4: Pre-shift the port number 2016-02-24 15:59:06 +01:00
i2c-pmcmsp.c
i2c-pnx.c
i2c-powermac.c i2c: powermac: use new 8 bit address helper function 2016-04-11 18:54:59 +02:00
i2c-puv3.c
i2c-pxa-pci.c
i2c-pxa.c
i2c-qup.c Merge branch 'i2c/for-4.8' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux 2016-07-27 14:19:25 -07:00
i2c-rcar.c i2c: rcar: use proper device with dma_mapping_error 2016-08-25 18:48:47 +02:00
i2c-riic.c
i2c-rk3x.c i2c: rk3x: Restore clock settings at resume time 2016-09-08 22:50:33 +02:00
i2c-robotfuzz-osif.c i2c: robotfuzz-osif: Constify osif_table 2016-06-13 22:32:09 +02:00
i2c-s3c2410.c i2c: s3c2410: Check clk_prepare_enable() return value 2016-04-26 00:32:07 +02:00
i2c-scmi.c
i2c-sh7760.c
i2c-sh_mobile.c i2c: sh_mobile: use proper device with dma_mapping_error 2016-08-25 18:48:12 +02:00
i2c-sibyte.c
i2c-simtec.c
i2c-sirf.c i2c: sirf: use new 8 bit address helper function 2016-04-11 18:54:59 +02:00
i2c-sis96x.c
i2c-sis630.c
i2c-sis5595.c
i2c-st.c i2c: st: Implement bus clear 2016-05-13 12:40:15 +02:00
i2c-stu300.c
i2c-sun6i-p2wi.c
i2c-taos-evm.c i2c: taos-evm: replace simple_strtoul by kstrtou8 2015-11-30 18:37:22 +01:00
i2c-tegra.c i2c: tegra: Correct error path in probe 2016-07-06 00:20:37 +09:00
i2c-tiny-usb.c
i2c-uniphier-f.c i2c: uniphier: add "\n" at the end of error log 2016-04-27 19:09:04 +02:00
i2c-uniphier.c i2c: uniphier: add "\n" at the end of error log 2016-04-27 19:09:04 +02:00
i2c-versatile.c i2c: versatile: Convert to use resource managed devm_* APIs 2016-07-14 21:21:56 +09:00
i2c-via.c
i2c-viapro.c
i2c-viperboard.c
i2c-wmt.c
i2c-xgene-slimpro.c
i2c-xiic.c i2c: xiic: Implement power management 2016-03-03 22:25:17 +01:00
i2c-xlp9xx.c i2c: xlp9xx: add ACPI support for Broadcom Vulcan 2016-07-08 10:40:55 +09:00
i2c-xlr.c i2c: xlr: add interrupt support for Sigma Designs chips 2015-12-16 11:42:58 +01:00
Kconfig i2c: brcmstb: Make the driver buildable on BMIPS_GENERIC 2016-07-15 15:00:01 +09:00
Makefile
scx200_acb.c