Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 311095
b: refs/heads/master
c: daf7317
h: refs/heads/master
i:
  311093: a295e2b
  311091: aedb244
  311087: e628939
v: v3
  • Loading branch information
Linus Walleij committed Jun 17, 2012
1 parent 7e28057 commit 99954fa
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 2 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 14e1e9f5cadb7cff3a2846c27cc1b9c8f207ee18
refs/heads/master: daf731748f978efb4f741d19b499236e03bf667f
22 changes: 21 additions & 1 deletion trunk/drivers/pinctrl/pinctrl-nomadik.c
Original file line number Diff line number Diff line change
Expand Up @@ -1438,7 +1438,27 @@ static int nmk_pmx_enable(struct pinctrl_dev *pctldev, unsigned function,

dev_dbg(npct->dev, "enable group %s, %u pins\n", g->name, g->npins);

/* Handle this special glitch on altfunction C */
/*
* If we're setting altfunc C by setting both AFSLA and AFSLB to 1,
* we may pass through an undesired state. In this case we take
* some extra care.
*
* Safe sequence used to switch IOs between GPIO and Alternate-C mode:
* - Save SLPM registers (since we have a shadow register in the
* nmk_chip we're using that as backup)
* - Set SLPM=0 for the IOs you want to switch and others to 1
* - Configure the GPIO registers for the IOs that are being switched
* - Set IOFORCE=1
* - Modify the AFLSA/B registers for the IOs that are being switched
* - Set IOFORCE=0
* - Restore SLPM registers
* - Any spurious wake up event during switch sequence to be ignored
* and cleared
*
* We REALLY need to save ALL slpm registers, because the external
* IOFORCE will switch *all* ports to their sleepmode setting to as
* to avoid glitches. (Not just one port!)
*/
glitch = (g->altsetting == NMK_GPIO_ALT_C);

if (glitch) {
Expand Down

0 comments on commit 99954fa

Please sign in to comment.