core.c 60 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Core driver for the pin control subsystem
  4. *
  5. * Copyright (C) 2011-2012 ST-Ericsson SA
  6. * Written on behalf of Linaro for ST-Ericsson
  7. * Based on bits of regulator core, gpio core and clk core
  8. *
  9. * Author: Linus Walleij <linus.walleij@linaro.org>
  10. *
  11. * Copyright (C) 2012 NVIDIA CORPORATION. All rights reserved.
  12. */
  13. #define pr_fmt(fmt) "pinctrl core: " fmt
  14. #include <linux/array_size.h>
  15. #include <linux/cleanup.h>
  16. #include <linux/debugfs.h>
  17. #include <linux/device.h>
  18. #include <linux/err.h>
  19. #include <linux/export.h>
  20. #include <linux/init.h>
  21. #include <linux/kref.h>
  22. #include <linux/list.h>
  23. #include <linux/seq_file.h>
  24. #include <linux/slab.h>
  25. #include <linux/gpio.h>
  26. #include <linux/gpio/driver.h>
  27. #include <linux/pinctrl/consumer.h>
  28. #include <linux/pinctrl/devinfo.h>
  29. #include <linux/pinctrl/machine.h>
  30. #include <linux/pinctrl/pinctrl.h>
  31. #include "core.h"
  32. #include "devicetree.h"
  33. #include "pinconf.h"
  34. #include "pinmux.h"
  35. static bool pinctrl_dummy_state;
  36. /* Mutex taken to protect pinctrl_list */
  37. static DEFINE_MUTEX(pinctrl_list_mutex);
  38. /* Mutex taken to protect pinctrl_maps */
  39. DEFINE_MUTEX(pinctrl_maps_mutex);
  40. /* Mutex taken to protect pinctrldev_list */
  41. static DEFINE_MUTEX(pinctrldev_list_mutex);
  42. /* Global list of pin control devices (struct pinctrl_dev) */
  43. static LIST_HEAD(pinctrldev_list);
  44. /* List of pin controller handles (struct pinctrl) */
  45. static LIST_HEAD(pinctrl_list);
  46. /* List of pinctrl maps (struct pinctrl_maps) */
  47. LIST_HEAD(pinctrl_maps);
  48. /**
  49. * pinctrl_provide_dummies() - indicate if pinctrl provides dummy state support
  50. *
  51. * Usually this function is called by platforms without pinctrl driver support
  52. * but run with some shared drivers using pinctrl APIs.
  53. * After calling this function, the pinctrl core will return successfully
  54. * with creating a dummy state for the driver to keep going smoothly.
  55. */
  56. void pinctrl_provide_dummies(void)
  57. {
  58. pinctrl_dummy_state = true;
  59. }
  60. EXPORT_SYMBOL_GPL(pinctrl_provide_dummies);
  61. const char *pinctrl_dev_get_name(struct pinctrl_dev *pctldev)
  62. {
  63. /* We're not allowed to register devices without name */
  64. return pctldev->desc->name;
  65. }
  66. EXPORT_SYMBOL_GPL(pinctrl_dev_get_name);
  67. const char *pinctrl_dev_get_devname(struct pinctrl_dev *pctldev)
  68. {
  69. return dev_name(pctldev->dev);
  70. }
  71. EXPORT_SYMBOL_GPL(pinctrl_dev_get_devname);
  72. void *pinctrl_dev_get_drvdata(struct pinctrl_dev *pctldev)
  73. {
  74. return pctldev->driver_data;
  75. }
  76. EXPORT_SYMBOL_GPL(pinctrl_dev_get_drvdata);
  77. /**
  78. * get_pinctrl_dev_from_devname() - look up pin controller device
  79. * @devname: the name of a device instance, as returned by dev_name()
  80. *
  81. * Looks up a pin control device matching a certain device name or pure device
  82. * pointer, the pure device pointer will take precedence.
  83. */
  84. struct pinctrl_dev *get_pinctrl_dev_from_devname(const char *devname)
  85. {
  86. struct pinctrl_dev *pctldev;
  87. if (!devname)
  88. return NULL;
  89. mutex_lock(&pinctrldev_list_mutex);
  90. list_for_each_entry(pctldev, &pinctrldev_list, node) {
  91. if (!strcmp(dev_name(pctldev->dev), devname)) {
  92. /* Matched on device name */
  93. mutex_unlock(&pinctrldev_list_mutex);
  94. return pctldev;
  95. }
  96. }
  97. mutex_unlock(&pinctrldev_list_mutex);
  98. return NULL;
  99. }
  100. struct pinctrl_dev *get_pinctrl_dev_from_of_node(struct device_node *np)
  101. {
  102. struct pinctrl_dev *pctldev;
  103. mutex_lock(&pinctrldev_list_mutex);
  104. list_for_each_entry(pctldev, &pinctrldev_list, node)
  105. if (device_match_of_node(pctldev->dev, np)) {
  106. mutex_unlock(&pinctrldev_list_mutex);
  107. return pctldev;
  108. }
  109. mutex_unlock(&pinctrldev_list_mutex);
  110. return NULL;
  111. }
  112. /**
  113. * pin_get_from_name() - look up a pin number from a name
  114. * @pctldev: the pin control device to lookup the pin on
  115. * @name: the name of the pin to look up
  116. */
  117. int pin_get_from_name(struct pinctrl_dev *pctldev, const char *name)
  118. {
  119. unsigned int i, pin;
  120. /* The pin number can be retrived from the pin controller descriptor */
  121. for (i = 0; i < pctldev->desc->npins; i++) {
  122. struct pin_desc *desc;
  123. pin = pctldev->desc->pins[i].number;
  124. desc = pin_desc_get(pctldev, pin);
  125. /* Pin space may be sparse */
  126. if (desc && !strcmp(name, desc->name))
  127. return pin;
  128. }
  129. return -EINVAL;
  130. }
  131. /**
  132. * pin_get_name() - look up a pin name from a pin id
  133. * @pctldev: the pin control device to lookup the pin on
  134. * @pin: pin number/id to look up
  135. */
  136. const char *pin_get_name(struct pinctrl_dev *pctldev, const unsigned int pin)
  137. {
  138. const struct pin_desc *desc;
  139. desc = pin_desc_get(pctldev, pin);
  140. if (!desc) {
  141. dev_err(pctldev->dev, "failed to get pin(%d) name\n",
  142. pin);
  143. return NULL;
  144. }
  145. return desc->name;
  146. }
  147. EXPORT_SYMBOL_GPL(pin_get_name);
  148. /* Deletes a range of pin descriptors */
  149. static void pinctrl_free_pindescs(struct pinctrl_dev *pctldev,
  150. const struct pinctrl_pin_desc *pins,
  151. unsigned int num_pins)
  152. {
  153. int i;
  154. for (i = 0; i < num_pins; i++) {
  155. struct pin_desc *pindesc;
  156. pindesc = radix_tree_lookup(&pctldev->pin_desc_tree,
  157. pins[i].number);
  158. if (pindesc) {
  159. radix_tree_delete(&pctldev->pin_desc_tree,
  160. pins[i].number);
  161. if (pindesc->dynamic_name)
  162. kfree(pindesc->name);
  163. }
  164. kfree(pindesc);
  165. }
  166. }
  167. static int pinctrl_register_one_pin(struct pinctrl_dev *pctldev,
  168. const struct pinctrl_pin_desc *pin)
  169. {
  170. struct pin_desc *pindesc;
  171. int error;
  172. pindesc = pin_desc_get(pctldev, pin->number);
  173. if (pindesc) {
  174. dev_err(pctldev->dev, "pin %d already registered\n",
  175. pin->number);
  176. return -EINVAL;
  177. }
  178. pindesc = kzalloc_obj(*pindesc);
  179. if (!pindesc)
  180. return -ENOMEM;
  181. /* Set owner */
  182. pindesc->pctldev = pctldev;
  183. #ifdef CONFIG_PINMUX
  184. mutex_init(&pindesc->mux_lock);
  185. #endif
  186. /* Copy basic pin info */
  187. if (pin->name) {
  188. pindesc->name = pin->name;
  189. } else {
  190. pindesc->name = kasprintf(GFP_KERNEL, "PIN%u", pin->number);
  191. if (!pindesc->name) {
  192. error = -ENOMEM;
  193. goto failed;
  194. }
  195. pindesc->dynamic_name = true;
  196. }
  197. pindesc->drv_data = pin->drv_data;
  198. error = radix_tree_insert(&pctldev->pin_desc_tree, pin->number, pindesc);
  199. if (error)
  200. goto failed;
  201. pr_debug("registered pin %d (%s) on %s\n",
  202. pin->number, pindesc->name, pctldev->desc->name);
  203. return 0;
  204. failed:
  205. kfree(pindesc);
  206. return error;
  207. }
  208. static int pinctrl_register_pins(struct pinctrl_dev *pctldev,
  209. const struct pinctrl_pin_desc *pins,
  210. unsigned int num_descs)
  211. {
  212. unsigned int i;
  213. int ret = 0;
  214. for (i = 0; i < num_descs; i++) {
  215. ret = pinctrl_register_one_pin(pctldev, &pins[i]);
  216. if (ret)
  217. return ret;
  218. }
  219. return 0;
  220. }
  221. /**
  222. * gpio_to_pin() - GPIO range GPIO number to pin number translation
  223. * @range: GPIO range used for the translation
  224. * @gc: GPIO chip structure from the GPIO subsystem
  225. * @offset: hardware offset of the GPIO relative to the controller
  226. *
  227. * Finds the pin number for a given GPIO using the specified GPIO range
  228. * as a base for translation. The distinction between linear GPIO ranges
  229. * and pin list based GPIO ranges is managed correctly by this function.
  230. *
  231. * This function assumes the gpio is part of the specified GPIO range, use
  232. * only after making sure this is the case (e.g. by calling it on the
  233. * result of successful pinctrl_get_device_gpio_range calls)!
  234. */
  235. static inline int gpio_to_pin(struct pinctrl_gpio_range *range,
  236. struct gpio_chip *gc, unsigned int offset)
  237. {
  238. unsigned int pin = gc->base + offset - range->base;
  239. if (range->pins)
  240. return range->pins[pin];
  241. else
  242. return range->pin_base + pin;
  243. }
  244. /**
  245. * pinctrl_match_gpio_range() - check if a certain GPIO pin is in range
  246. * @pctldev: pin controller device to check
  247. * @gc: GPIO chip structure from the GPIO subsystem
  248. * @offset: hardware offset of the GPIO relative to the controller
  249. *
  250. * Tries to match a GPIO pin number to the ranges handled by a certain pin
  251. * controller, return the range or NULL
  252. */
  253. static struct pinctrl_gpio_range *
  254. pinctrl_match_gpio_range(struct pinctrl_dev *pctldev, struct gpio_chip *gc,
  255. unsigned int offset)
  256. {
  257. struct pinctrl_gpio_range *range;
  258. mutex_lock(&pctldev->mutex);
  259. /* Loop over the ranges */
  260. list_for_each_entry(range, &pctldev->gpio_ranges, node) {
  261. /* Check if we're in the valid range */
  262. if ((gc->base + offset) >= range->base &&
  263. (gc->base + offset) < range->base + range->npins) {
  264. mutex_unlock(&pctldev->mutex);
  265. return range;
  266. }
  267. }
  268. mutex_unlock(&pctldev->mutex);
  269. return NULL;
  270. }
  271. /**
  272. * pinctrl_ready_for_gpio_range() - check if other GPIO pins of
  273. * the same GPIO chip are in range
  274. * @gc: GPIO chip structure from the GPIO subsystem
  275. * @offset: hardware offset of the GPIO relative to the controller
  276. *
  277. * This function is complement of pinctrl_match_gpio_range(). If the return
  278. * value of pinctrl_match_gpio_range() is NULL, this function could be used
  279. * to check whether pinctrl device is ready or not. Maybe some GPIO pins
  280. * of the same GPIO chip don't have back-end pinctrl interface.
  281. * If the return value is true, it means that pinctrl device is ready & the
  282. * certain GPIO pin doesn't have back-end pinctrl device. If the return value
  283. * is false, it means that pinctrl device may not be ready.
  284. */
  285. #ifdef CONFIG_GPIOLIB
  286. static bool pinctrl_ready_for_gpio_range(struct gpio_chip *gc,
  287. unsigned int offset)
  288. {
  289. struct pinctrl_dev *pctldev;
  290. struct pinctrl_gpio_range *range = NULL;
  291. mutex_lock(&pinctrldev_list_mutex);
  292. /* Loop over the pin controllers */
  293. list_for_each_entry(pctldev, &pinctrldev_list, node) {
  294. /* Loop over the ranges */
  295. mutex_lock(&pctldev->mutex);
  296. list_for_each_entry(range, &pctldev->gpio_ranges, node) {
  297. /* Check if any gpio range overlapped with gpio chip */
  298. if (range->base + range->npins - 1 < gc->base ||
  299. range->base > gc->base + gc->ngpio - 1)
  300. continue;
  301. mutex_unlock(&pctldev->mutex);
  302. mutex_unlock(&pinctrldev_list_mutex);
  303. return true;
  304. }
  305. mutex_unlock(&pctldev->mutex);
  306. }
  307. mutex_unlock(&pinctrldev_list_mutex);
  308. return false;
  309. }
  310. #else
  311. static inline bool
  312. pinctrl_ready_for_gpio_range(struct gpio_chip *gc, unsigned int offset)
  313. {
  314. return true;
  315. }
  316. #endif
  317. /**
  318. * pinctrl_get_device_gpio_range() - find device for GPIO range
  319. * @gc: GPIO chip structure from the GPIO subsystem
  320. * @offset: hardware offset of the GPIO relative to the controller
  321. * @outdev: the pin control device if found
  322. * @outrange: the GPIO range if found
  323. *
  324. * Find the pin controller handling a certain GPIO pin from the pinspace of
  325. * the GPIO subsystem, return the device and the matching GPIO range. Returns
  326. * -EPROBE_DEFER if the GPIO range could not be found in any device since it
  327. * may still have not been registered.
  328. */
  329. static int pinctrl_get_device_gpio_range(struct gpio_chip *gc,
  330. unsigned int offset,
  331. struct pinctrl_dev **outdev,
  332. struct pinctrl_gpio_range **outrange)
  333. {
  334. struct pinctrl_dev *pctldev;
  335. mutex_lock(&pinctrldev_list_mutex);
  336. /* Loop over the pin controllers */
  337. list_for_each_entry(pctldev, &pinctrldev_list, node) {
  338. struct pinctrl_gpio_range *range;
  339. range = pinctrl_match_gpio_range(pctldev, gc, offset);
  340. if (range) {
  341. *outdev = pctldev;
  342. *outrange = range;
  343. mutex_unlock(&pinctrldev_list_mutex);
  344. return 0;
  345. }
  346. }
  347. mutex_unlock(&pinctrldev_list_mutex);
  348. return -EPROBE_DEFER;
  349. }
  350. /**
  351. * pinctrl_add_gpio_range() - register a GPIO range for a controller
  352. * @pctldev: pin controller device to add the range to
  353. * @range: the GPIO range to add
  354. *
  355. * DEPRECATED: Don't use this function in new code. See section 2 of
  356. * Documentation/devicetree/bindings/gpio/gpio.txt on how to bind pinctrl and
  357. * gpio drivers.
  358. *
  359. * This adds a range of GPIOs to be handled by a certain pin controller. Call
  360. * this to register handled ranges after registering your pin controller.
  361. */
  362. void pinctrl_add_gpio_range(struct pinctrl_dev *pctldev,
  363. struct pinctrl_gpio_range *range)
  364. {
  365. mutex_lock(&pctldev->mutex);
  366. list_add_tail(&range->node, &pctldev->gpio_ranges);
  367. mutex_unlock(&pctldev->mutex);
  368. }
  369. EXPORT_SYMBOL_GPL(pinctrl_add_gpio_range);
  370. void pinctrl_add_gpio_ranges(struct pinctrl_dev *pctldev,
  371. struct pinctrl_gpio_range *ranges,
  372. unsigned int nranges)
  373. {
  374. int i;
  375. for (i = 0; i < nranges; i++)
  376. pinctrl_add_gpio_range(pctldev, &ranges[i]);
  377. }
  378. EXPORT_SYMBOL_GPL(pinctrl_add_gpio_ranges);
  379. struct pinctrl_dev *pinctrl_find_and_add_gpio_range(const char *devname,
  380. struct pinctrl_gpio_range *range)
  381. {
  382. struct pinctrl_dev *pctldev;
  383. pctldev = get_pinctrl_dev_from_devname(devname);
  384. /*
  385. * If we can't find this device, let's assume that is because
  386. * it has not probed yet, so the driver trying to register this
  387. * range need to defer probing.
  388. */
  389. if (!pctldev)
  390. return ERR_PTR(-EPROBE_DEFER);
  391. pinctrl_add_gpio_range(pctldev, range);
  392. return pctldev;
  393. }
  394. EXPORT_SYMBOL_GPL(pinctrl_find_and_add_gpio_range);
  395. int pinctrl_get_group_pins(struct pinctrl_dev *pctldev, const char *pin_group,
  396. const unsigned int **pins, unsigned int *num_pins)
  397. {
  398. const struct pinctrl_ops *pctlops = pctldev->desc->pctlops;
  399. int gs;
  400. if (!pctlops->get_group_pins)
  401. return -EINVAL;
  402. gs = pinctrl_get_group_selector(pctldev, pin_group);
  403. if (gs < 0)
  404. return gs;
  405. return pctlops->get_group_pins(pctldev, gs, pins, num_pins);
  406. }
  407. EXPORT_SYMBOL_GPL(pinctrl_get_group_pins);
  408. struct pinctrl_gpio_range *
  409. pinctrl_find_gpio_range_from_pin_nolock(struct pinctrl_dev *pctldev,
  410. unsigned int pin)
  411. {
  412. struct pinctrl_gpio_range *range;
  413. /* Loop over the ranges */
  414. list_for_each_entry(range, &pctldev->gpio_ranges, node) {
  415. /* Check if we're in the valid range */
  416. if (range->pins) {
  417. int a;
  418. for (a = 0; a < range->npins; a++) {
  419. if (range->pins[a] == pin)
  420. return range;
  421. }
  422. } else if (pin >= range->pin_base &&
  423. pin < range->pin_base + range->npins)
  424. return range;
  425. }
  426. return NULL;
  427. }
  428. EXPORT_SYMBOL_GPL(pinctrl_find_gpio_range_from_pin_nolock);
  429. /**
  430. * pinctrl_find_gpio_range_from_pin() - locate the GPIO range for a pin
  431. * @pctldev: the pin controller device to look in
  432. * @pin: a controller-local number to find the range for
  433. */
  434. struct pinctrl_gpio_range *
  435. pinctrl_find_gpio_range_from_pin(struct pinctrl_dev *pctldev,
  436. unsigned int pin)
  437. {
  438. struct pinctrl_gpio_range *range;
  439. mutex_lock(&pctldev->mutex);
  440. range = pinctrl_find_gpio_range_from_pin_nolock(pctldev, pin);
  441. mutex_unlock(&pctldev->mutex);
  442. return range;
  443. }
  444. EXPORT_SYMBOL_GPL(pinctrl_find_gpio_range_from_pin);
  445. /**
  446. * pinctrl_remove_gpio_range() - remove a range of GPIOs from a pin controller
  447. * @pctldev: pin controller device to remove the range from
  448. * @range: the GPIO range to remove
  449. */
  450. void pinctrl_remove_gpio_range(struct pinctrl_dev *pctldev,
  451. struct pinctrl_gpio_range *range)
  452. {
  453. mutex_lock(&pctldev->mutex);
  454. list_del(&range->node);
  455. mutex_unlock(&pctldev->mutex);
  456. }
  457. EXPORT_SYMBOL_GPL(pinctrl_remove_gpio_range);
  458. #ifdef CONFIG_GENERIC_PINCTRL_GROUPS
  459. /**
  460. * pinctrl_generic_get_group_count() - returns the number of pin groups
  461. * @pctldev: pin controller device
  462. */
  463. int pinctrl_generic_get_group_count(struct pinctrl_dev *pctldev)
  464. {
  465. return pctldev->num_groups;
  466. }
  467. EXPORT_SYMBOL_GPL(pinctrl_generic_get_group_count);
  468. /**
  469. * pinctrl_generic_get_group_name() - returns the name of a pin group
  470. * @pctldev: pin controller device
  471. * @selector: group number
  472. */
  473. const char *pinctrl_generic_get_group_name(struct pinctrl_dev *pctldev,
  474. unsigned int selector)
  475. {
  476. struct group_desc *group;
  477. group = radix_tree_lookup(&pctldev->pin_group_tree,
  478. selector);
  479. if (!group)
  480. return NULL;
  481. return group->grp.name;
  482. }
  483. EXPORT_SYMBOL_GPL(pinctrl_generic_get_group_name);
  484. /**
  485. * pinctrl_generic_get_group_pins() - gets the pin group pins
  486. * @pctldev: pin controller device
  487. * @selector: group number
  488. * @pins: pins in the group
  489. * @num_pins: number of pins in the group
  490. */
  491. int pinctrl_generic_get_group_pins(struct pinctrl_dev *pctldev,
  492. unsigned int selector,
  493. const unsigned int **pins,
  494. unsigned int *num_pins)
  495. {
  496. struct group_desc *group;
  497. group = radix_tree_lookup(&pctldev->pin_group_tree,
  498. selector);
  499. if (!group) {
  500. dev_err(pctldev->dev, "%s could not find pingroup%i\n",
  501. __func__, selector);
  502. return -EINVAL;
  503. }
  504. *pins = group->grp.pins;
  505. *num_pins = group->grp.npins;
  506. return 0;
  507. }
  508. EXPORT_SYMBOL_GPL(pinctrl_generic_get_group_pins);
  509. /**
  510. * pinctrl_generic_get_group() - returns a pin group based on the number
  511. * @pctldev: pin controller device
  512. * @selector: group number
  513. */
  514. struct group_desc *pinctrl_generic_get_group(struct pinctrl_dev *pctldev,
  515. unsigned int selector)
  516. {
  517. struct group_desc *group;
  518. group = radix_tree_lookup(&pctldev->pin_group_tree,
  519. selector);
  520. if (!group)
  521. return NULL;
  522. return group;
  523. }
  524. EXPORT_SYMBOL_GPL(pinctrl_generic_get_group);
  525. static int pinctrl_generic_group_name_to_selector(struct pinctrl_dev *pctldev,
  526. const char *function)
  527. {
  528. const struct pinctrl_ops *ops = pctldev->desc->pctlops;
  529. int ngroups = ops->get_groups_count(pctldev);
  530. int selector = 0;
  531. /* See if this pctldev has this group */
  532. while (selector < ngroups) {
  533. const char *gname = ops->get_group_name(pctldev, selector);
  534. if (gname && !strcmp(function, gname))
  535. return selector;
  536. selector++;
  537. }
  538. return -EINVAL;
  539. }
  540. /**
  541. * pinctrl_generic_add_group() - adds a new pin group
  542. * @pctldev: pin controller device
  543. * @name: name of the pin group
  544. * @pins: pins in the pin group
  545. * @num_pins: number of pins in the pin group
  546. * @data: pin controller driver specific data
  547. *
  548. * Note that the caller must take care of locking.
  549. */
  550. int pinctrl_generic_add_group(struct pinctrl_dev *pctldev, const char *name,
  551. const unsigned int *pins, int num_pins, void *data)
  552. {
  553. struct group_desc *group;
  554. int selector, error;
  555. if (!name)
  556. return -EINVAL;
  557. selector = pinctrl_generic_group_name_to_selector(pctldev, name);
  558. if (selector >= 0)
  559. return selector;
  560. selector = pctldev->num_groups;
  561. group = devm_kzalloc(pctldev->dev, sizeof(*group), GFP_KERNEL);
  562. if (!group)
  563. return -ENOMEM;
  564. *group = PINCTRL_GROUP_DESC(name, pins, num_pins, data);
  565. error = radix_tree_insert(&pctldev->pin_group_tree, selector, group);
  566. if (error)
  567. return error;
  568. pctldev->num_groups++;
  569. return selector;
  570. }
  571. EXPORT_SYMBOL_GPL(pinctrl_generic_add_group);
  572. /**
  573. * pinctrl_generic_remove_group() - removes a numbered pin group
  574. * @pctldev: pin controller device
  575. * @selector: group number
  576. *
  577. * Note that the caller must take care of locking.
  578. */
  579. int pinctrl_generic_remove_group(struct pinctrl_dev *pctldev,
  580. unsigned int selector)
  581. {
  582. struct group_desc *group;
  583. group = radix_tree_lookup(&pctldev->pin_group_tree,
  584. selector);
  585. if (!group)
  586. return -ENOENT;
  587. radix_tree_delete(&pctldev->pin_group_tree, selector);
  588. devm_kfree(pctldev->dev, group);
  589. pctldev->num_groups--;
  590. return 0;
  591. }
  592. EXPORT_SYMBOL_GPL(pinctrl_generic_remove_group);
  593. /**
  594. * pinctrl_generic_free_groups() - removes all pin groups
  595. * @pctldev: pin controller device
  596. *
  597. * Note that the caller must take care of locking. The pinctrl groups
  598. * are allocated with devm_kzalloc() so no need to free them here.
  599. */
  600. static void pinctrl_generic_free_groups(struct pinctrl_dev *pctldev)
  601. {
  602. struct radix_tree_iter iter;
  603. void __rcu **slot;
  604. radix_tree_for_each_slot(slot, &pctldev->pin_group_tree, &iter, 0)
  605. radix_tree_delete(&pctldev->pin_group_tree, iter.index);
  606. pctldev->num_groups = 0;
  607. }
  608. #else
  609. static inline void pinctrl_generic_free_groups(struct pinctrl_dev *pctldev)
  610. {
  611. }
  612. #endif /* CONFIG_GENERIC_PINCTRL_GROUPS */
  613. /**
  614. * pinctrl_get_group_selector() - returns the group selector for a group
  615. * @pctldev: the pin controller handling the group
  616. * @pin_group: the pin group to look up
  617. */
  618. int pinctrl_get_group_selector(struct pinctrl_dev *pctldev,
  619. const char *pin_group)
  620. {
  621. const struct pinctrl_ops *pctlops = pctldev->desc->pctlops;
  622. unsigned int ngroups = pctlops->get_groups_count(pctldev);
  623. unsigned int group_selector = 0;
  624. while (group_selector < ngroups) {
  625. const char *gname = pctlops->get_group_name(pctldev,
  626. group_selector);
  627. if (gname && !strcmp(gname, pin_group)) {
  628. dev_dbg(pctldev->dev,
  629. "found group selector %u for %s\n",
  630. group_selector,
  631. pin_group);
  632. return group_selector;
  633. }
  634. group_selector++;
  635. }
  636. dev_err(pctldev->dev, "does not have pin group %s\n",
  637. pin_group);
  638. return -EINVAL;
  639. }
  640. bool pinctrl_gpio_can_use_line(struct gpio_chip *gc, unsigned int offset)
  641. {
  642. struct pinctrl_dev *pctldev;
  643. struct pinctrl_gpio_range *range;
  644. bool result;
  645. int pin;
  646. /*
  647. * Try to obtain GPIO range, if it fails
  648. * we're probably dealing with GPIO driver
  649. * without a backing pin controller - bail out.
  650. */
  651. if (pinctrl_get_device_gpio_range(gc, offset, &pctldev, &range))
  652. return true;
  653. mutex_lock(&pctldev->mutex);
  654. /* Convert to the pin controllers number space */
  655. pin = gpio_to_pin(range, gc, offset);
  656. result = pinmux_can_be_used_for_gpio(pctldev, pin);
  657. mutex_unlock(&pctldev->mutex);
  658. return result;
  659. }
  660. EXPORT_SYMBOL_GPL(pinctrl_gpio_can_use_line);
  661. /**
  662. * pinctrl_gpio_request() - request a single pin to be used as GPIO
  663. * @gc: GPIO chip structure from the GPIO subsystem
  664. * @offset: hardware offset of the GPIO relative to the controller
  665. *
  666. * This function should *ONLY* be used from gpiolib-based GPIO drivers,
  667. * as part of their gpio_request() semantics, platforms and individual drivers
  668. * shall *NOT* request GPIO pins to be muxed in.
  669. */
  670. int pinctrl_gpio_request(struct gpio_chip *gc, unsigned int offset)
  671. {
  672. struct pinctrl_gpio_range *range;
  673. struct pinctrl_dev *pctldev;
  674. int ret, pin;
  675. ret = pinctrl_get_device_gpio_range(gc, offset, &pctldev, &range);
  676. if (ret) {
  677. if (pinctrl_ready_for_gpio_range(gc, offset))
  678. ret = 0;
  679. return ret;
  680. }
  681. mutex_lock(&pctldev->mutex);
  682. /* Convert to the pin controllers number space */
  683. pin = gpio_to_pin(range, gc, offset);
  684. ret = pinmux_request_gpio(pctldev, range, pin, gc->base + offset);
  685. mutex_unlock(&pctldev->mutex);
  686. return ret;
  687. }
  688. EXPORT_SYMBOL_GPL(pinctrl_gpio_request);
  689. /**
  690. * pinctrl_gpio_free() - free control on a single pin, currently used as GPIO
  691. * @gc: GPIO chip structure from the GPIO subsystem
  692. * @offset: hardware offset of the GPIO relative to the controller
  693. *
  694. * This function should *ONLY* be used from gpiolib-based GPIO drivers,
  695. * as part of their gpio_request() semantics, platforms and individual drivers
  696. * shall *NOT* request GPIO pins to be muxed in.
  697. */
  698. void pinctrl_gpio_free(struct gpio_chip *gc, unsigned int offset)
  699. {
  700. struct pinctrl_gpio_range *range;
  701. struct pinctrl_dev *pctldev;
  702. int ret, pin;
  703. ret = pinctrl_get_device_gpio_range(gc, offset, &pctldev, &range);
  704. if (ret)
  705. return;
  706. mutex_lock(&pctldev->mutex);
  707. /* Convert to the pin controllers number space */
  708. pin = gpio_to_pin(range, gc, offset);
  709. pinmux_free_gpio(pctldev, pin, range);
  710. mutex_unlock(&pctldev->mutex);
  711. }
  712. EXPORT_SYMBOL_GPL(pinctrl_gpio_free);
  713. static int pinctrl_gpio_direction(struct gpio_chip *gc, unsigned int offset,
  714. bool input)
  715. {
  716. struct pinctrl_dev *pctldev;
  717. struct pinctrl_gpio_range *range;
  718. int ret;
  719. int pin;
  720. ret = pinctrl_get_device_gpio_range(gc, offset, &pctldev, &range);
  721. if (ret) {
  722. return ret;
  723. }
  724. mutex_lock(&pctldev->mutex);
  725. /* Convert to the pin controllers number space */
  726. pin = gpio_to_pin(range, gc, offset);
  727. ret = pinmux_gpio_direction(pctldev, range, pin, input);
  728. mutex_unlock(&pctldev->mutex);
  729. return ret;
  730. }
  731. /**
  732. * pinctrl_gpio_direction_input() - request a GPIO pin to go into input mode
  733. * @gc: GPIO chip structure from the GPIO subsystem
  734. * @offset: hardware offset of the GPIO relative to the controller
  735. *
  736. * This function should *ONLY* be used from gpiolib-based GPIO drivers,
  737. * as part of their gpio_direction_input() semantics, platforms and individual
  738. * drivers shall *NOT* touch pin control GPIO calls.
  739. */
  740. int pinctrl_gpio_direction_input(struct gpio_chip *gc, unsigned int offset)
  741. {
  742. return pinctrl_gpio_direction(gc, offset, true);
  743. }
  744. EXPORT_SYMBOL_GPL(pinctrl_gpio_direction_input);
  745. /**
  746. * pinctrl_gpio_direction_output() - request a GPIO pin to go into output mode
  747. * @gc: GPIO chip structure from the GPIO subsystem
  748. * @offset: hardware offset of the GPIO relative to the controller
  749. *
  750. * This function should *ONLY* be used from gpiolib-based GPIO drivers,
  751. * as part of their gpio_direction_output() semantics, platforms and individual
  752. * drivers shall *NOT* touch pin control GPIO calls.
  753. */
  754. int pinctrl_gpio_direction_output(struct gpio_chip *gc, unsigned int offset)
  755. {
  756. return pinctrl_gpio_direction(gc, offset, false);
  757. }
  758. EXPORT_SYMBOL_GPL(pinctrl_gpio_direction_output);
  759. /**
  760. * pinctrl_gpio_set_config() - Apply config to given GPIO pin
  761. * @gc: GPIO chip structure from the GPIO subsystem
  762. * @offset: hardware offset of the GPIO relative to the controller
  763. * @config: the configuration to apply to the GPIO
  764. *
  765. * This function should *ONLY* be used from gpiolib-based GPIO drivers, if
  766. * they need to call the underlying pin controller to change GPIO config
  767. * (for example set debounce time).
  768. */
  769. int pinctrl_gpio_set_config(struct gpio_chip *gc, unsigned int offset,
  770. unsigned long config)
  771. {
  772. unsigned long configs[] = { config };
  773. struct pinctrl_gpio_range *range;
  774. struct pinctrl_dev *pctldev;
  775. int ret, pin;
  776. ret = pinctrl_get_device_gpio_range(gc, offset, &pctldev, &range);
  777. if (ret)
  778. return ret;
  779. mutex_lock(&pctldev->mutex);
  780. pin = gpio_to_pin(range, gc, offset);
  781. ret = pinconf_set_config(pctldev, pin, configs, ARRAY_SIZE(configs));
  782. mutex_unlock(&pctldev->mutex);
  783. return ret;
  784. }
  785. EXPORT_SYMBOL_GPL(pinctrl_gpio_set_config);
  786. static struct pinctrl_state *find_state(struct pinctrl *p,
  787. const char *name)
  788. {
  789. struct pinctrl_state *state;
  790. list_for_each_entry(state, &p->states, node)
  791. if (!strcmp(state->name, name))
  792. return state;
  793. return NULL;
  794. }
  795. static struct pinctrl_state *create_state(struct pinctrl *p,
  796. const char *name)
  797. {
  798. struct pinctrl_state *state;
  799. state = kzalloc_obj(*state);
  800. if (!state)
  801. return ERR_PTR(-ENOMEM);
  802. state->name = name;
  803. INIT_LIST_HEAD(&state->settings);
  804. list_add_tail(&state->node, &p->states);
  805. return state;
  806. }
  807. static int add_setting(struct pinctrl *p, struct pinctrl_dev *pctldev,
  808. const struct pinctrl_map *map)
  809. {
  810. struct pinctrl_state *state;
  811. struct pinctrl_setting *setting;
  812. int ret;
  813. state = find_state(p, map->name);
  814. if (!state)
  815. state = create_state(p, map->name);
  816. if (IS_ERR(state))
  817. return PTR_ERR(state);
  818. if (map->type == PIN_MAP_TYPE_DUMMY_STATE)
  819. return 0;
  820. setting = kzalloc_obj(*setting);
  821. if (!setting)
  822. return -ENOMEM;
  823. setting->type = map->type;
  824. if (pctldev)
  825. setting->pctldev = pctldev;
  826. else
  827. setting->pctldev =
  828. get_pinctrl_dev_from_devname(map->ctrl_dev_name);
  829. if (!setting->pctldev) {
  830. kfree(setting);
  831. /* Do not defer probing of hogs (circular loop) */
  832. if (!strcmp(map->ctrl_dev_name, map->dev_name))
  833. return -ENODEV;
  834. /*
  835. * OK let us guess that the driver is not there yet, and
  836. * let's defer obtaining this pinctrl handle to later...
  837. */
  838. dev_info(p->dev, "unknown pinctrl device %s in map entry, deferring probe",
  839. map->ctrl_dev_name);
  840. return -EPROBE_DEFER;
  841. }
  842. setting->dev_name = map->dev_name;
  843. switch (map->type) {
  844. case PIN_MAP_TYPE_MUX_GROUP:
  845. ret = pinmux_map_to_setting(map, setting);
  846. break;
  847. case PIN_MAP_TYPE_CONFIGS_PIN:
  848. case PIN_MAP_TYPE_CONFIGS_GROUP:
  849. ret = pinconf_map_to_setting(map, setting);
  850. break;
  851. default:
  852. ret = -EINVAL;
  853. break;
  854. }
  855. if (ret < 0) {
  856. kfree(setting);
  857. return ret;
  858. }
  859. list_add_tail(&setting->node, &state->settings);
  860. return 0;
  861. }
  862. static struct pinctrl *find_pinctrl(struct device *dev)
  863. {
  864. struct pinctrl *p;
  865. mutex_lock(&pinctrl_list_mutex);
  866. list_for_each_entry(p, &pinctrl_list, node)
  867. if (p->dev == dev) {
  868. mutex_unlock(&pinctrl_list_mutex);
  869. return p;
  870. }
  871. mutex_unlock(&pinctrl_list_mutex);
  872. return NULL;
  873. }
  874. static void pinctrl_free(struct pinctrl *p, bool inlist);
  875. static struct pinctrl *create_pinctrl(struct device *dev,
  876. struct pinctrl_dev *pctldev)
  877. {
  878. struct pinctrl *p;
  879. const char *devname;
  880. struct pinctrl_maps *maps_node;
  881. const struct pinctrl_map *map;
  882. int ret;
  883. /*
  884. * create the state cookie holder struct pinctrl for each
  885. * mapping, this is what consumers will get when requesting
  886. * a pin control handle with pinctrl_get()
  887. */
  888. p = kzalloc_obj(*p);
  889. if (!p)
  890. return ERR_PTR(-ENOMEM);
  891. p->dev = dev;
  892. INIT_LIST_HEAD(&p->states);
  893. INIT_LIST_HEAD(&p->dt_maps);
  894. ret = pinctrl_dt_to_map(p, pctldev);
  895. if (ret < 0) {
  896. kfree(p);
  897. return ERR_PTR(ret);
  898. }
  899. devname = dev_name(dev);
  900. mutex_lock(&pinctrl_maps_mutex);
  901. /* Iterate over the pin control maps to locate the right ones */
  902. for_each_pin_map(maps_node, map) {
  903. /* Map must be for this device */
  904. if (strcmp(map->dev_name, devname))
  905. continue;
  906. /*
  907. * If pctldev is not null, we are claiming hog for it,
  908. * that means, setting that is served by pctldev by itself.
  909. *
  910. * Thus we must skip map that is for this device but is served
  911. * by other device.
  912. */
  913. if (pctldev &&
  914. strcmp(dev_name(pctldev->dev), map->ctrl_dev_name))
  915. continue;
  916. ret = add_setting(p, pctldev, map);
  917. /*
  918. * At this point the adding of a setting may:
  919. *
  920. * - Defer, if the pinctrl device is not yet available
  921. * - Fail, if the pinctrl device is not yet available,
  922. * AND the setting is a hog. We cannot defer that, since
  923. * the hog will kick in immediately after the device
  924. * is registered.
  925. *
  926. * If the error returned was not -EPROBE_DEFER then we
  927. * accumulate the errors to see if we end up with
  928. * an -EPROBE_DEFER later, as that is the worst case.
  929. */
  930. if (ret == -EPROBE_DEFER) {
  931. mutex_unlock(&pinctrl_maps_mutex);
  932. pinctrl_free(p, false);
  933. return ERR_PTR(ret);
  934. }
  935. }
  936. mutex_unlock(&pinctrl_maps_mutex);
  937. if (ret < 0) {
  938. /* If some other error than deferral occurred, return here */
  939. pinctrl_free(p, false);
  940. return ERR_PTR(ret);
  941. }
  942. kref_init(&p->users);
  943. /* Add the pinctrl handle to the global list */
  944. mutex_lock(&pinctrl_list_mutex);
  945. list_add_tail(&p->node, &pinctrl_list);
  946. mutex_unlock(&pinctrl_list_mutex);
  947. return p;
  948. }
  949. /**
  950. * pinctrl_get() - retrieves the pinctrl handle for a device
  951. * @dev: the device to obtain the handle for
  952. */
  953. struct pinctrl *pinctrl_get(struct device *dev)
  954. {
  955. struct pinctrl *p;
  956. if (WARN_ON(!dev))
  957. return ERR_PTR(-EINVAL);
  958. /*
  959. * See if somebody else (such as the device core) has already
  960. * obtained a handle to the pinctrl for this device. In that case,
  961. * return another pointer to it.
  962. */
  963. p = find_pinctrl(dev);
  964. if (p) {
  965. dev_dbg(dev, "obtain a copy of previously claimed pinctrl\n");
  966. kref_get(&p->users);
  967. return p;
  968. }
  969. return create_pinctrl(dev, NULL);
  970. }
  971. EXPORT_SYMBOL_GPL(pinctrl_get);
  972. static void pinctrl_free_setting(bool disable_setting,
  973. struct pinctrl_setting *setting)
  974. {
  975. switch (setting->type) {
  976. case PIN_MAP_TYPE_MUX_GROUP:
  977. if (disable_setting)
  978. pinmux_disable_setting(setting);
  979. pinmux_free_setting(setting);
  980. break;
  981. case PIN_MAP_TYPE_CONFIGS_PIN:
  982. case PIN_MAP_TYPE_CONFIGS_GROUP:
  983. pinconf_free_setting(setting);
  984. break;
  985. default:
  986. break;
  987. }
  988. }
  989. static void pinctrl_free(struct pinctrl *p, bool inlist)
  990. {
  991. struct pinctrl_state *state, *n1;
  992. struct pinctrl_setting *setting, *n2;
  993. mutex_lock(&pinctrl_list_mutex);
  994. list_for_each_entry_safe(state, n1, &p->states, node) {
  995. list_for_each_entry_safe(setting, n2, &state->settings, node) {
  996. pinctrl_free_setting(state == p->state, setting);
  997. list_del(&setting->node);
  998. kfree(setting);
  999. }
  1000. list_del(&state->node);
  1001. kfree(state);
  1002. }
  1003. pinctrl_dt_free_maps(p);
  1004. if (inlist)
  1005. list_del(&p->node);
  1006. kfree(p);
  1007. mutex_unlock(&pinctrl_list_mutex);
  1008. }
  1009. /**
  1010. * pinctrl_release() - release the pinctrl handle
  1011. * @kref: the kref in the pinctrl being released
  1012. */
  1013. static void pinctrl_release(struct kref *kref)
  1014. {
  1015. struct pinctrl *p = container_of(kref, struct pinctrl, users);
  1016. pinctrl_free(p, true);
  1017. }
  1018. /**
  1019. * pinctrl_put() - decrease use count on a previously claimed pinctrl handle
  1020. * @p: the pinctrl handle to release
  1021. */
  1022. void pinctrl_put(struct pinctrl *p)
  1023. {
  1024. kref_put(&p->users, pinctrl_release);
  1025. }
  1026. EXPORT_SYMBOL_GPL(pinctrl_put);
  1027. /**
  1028. * pinctrl_lookup_state() - retrieves a state handle from a pinctrl handle
  1029. * @p: the pinctrl handle to retrieve the state from
  1030. * @name: the state name to retrieve
  1031. */
  1032. struct pinctrl_state *pinctrl_lookup_state(struct pinctrl *p,
  1033. const char *name)
  1034. {
  1035. struct pinctrl_state *state;
  1036. state = find_state(p, name);
  1037. if (!state) {
  1038. if (pinctrl_dummy_state) {
  1039. /* create dummy state */
  1040. dev_dbg(p->dev, "using pinctrl dummy state (%s)\n",
  1041. name);
  1042. state = create_state(p, name);
  1043. } else
  1044. state = ERR_PTR(-ENODEV);
  1045. }
  1046. return state;
  1047. }
  1048. EXPORT_SYMBOL_GPL(pinctrl_lookup_state);
  1049. static void pinctrl_link_add(struct pinctrl_dev *pctldev,
  1050. struct device *consumer)
  1051. {
  1052. if (pctldev->desc->link_consumers)
  1053. device_link_add(consumer, pctldev->dev,
  1054. DL_FLAG_PM_RUNTIME |
  1055. DL_FLAG_AUTOREMOVE_CONSUMER);
  1056. }
  1057. static void pinctrl_cond_disable_mux_setting(struct pinctrl_state *state,
  1058. struct pinctrl_setting *target_setting)
  1059. {
  1060. struct pinctrl_setting *setting;
  1061. list_for_each_entry(setting, &state->settings, node) {
  1062. if (target_setting && (&setting->node == &target_setting->node))
  1063. break;
  1064. if (setting->type == PIN_MAP_TYPE_MUX_GROUP)
  1065. pinmux_disable_setting(setting);
  1066. }
  1067. }
  1068. /**
  1069. * pinctrl_commit_state() - select/activate/program a pinctrl state to HW
  1070. * @p: the pinctrl handle for the device that requests configuration
  1071. * @state: the state handle to select/activate/program
  1072. */
  1073. static int pinctrl_commit_state(struct pinctrl *p, struct pinctrl_state *state)
  1074. {
  1075. struct pinctrl_setting *setting;
  1076. struct pinctrl_state *old_state = READ_ONCE(p->state);
  1077. int ret;
  1078. if (old_state) {
  1079. /*
  1080. * For each pinmux setting in the old state, forget SW's record
  1081. * of mux owner for that pingroup. Any pingroups which are
  1082. * still owned by the new state will be re-acquired by the call
  1083. * to pinmux_enable_setting() in the loop below.
  1084. */
  1085. pinctrl_cond_disable_mux_setting(old_state, NULL);
  1086. }
  1087. p->state = NULL;
  1088. /* Apply all the settings for the new state - pinmux first */
  1089. list_for_each_entry(setting, &state->settings, node) {
  1090. switch (setting->type) {
  1091. case PIN_MAP_TYPE_MUX_GROUP:
  1092. ret = pinmux_enable_setting(setting);
  1093. break;
  1094. case PIN_MAP_TYPE_CONFIGS_PIN:
  1095. case PIN_MAP_TYPE_CONFIGS_GROUP:
  1096. ret = 0;
  1097. break;
  1098. default:
  1099. ret = -EINVAL;
  1100. break;
  1101. }
  1102. if (ret < 0)
  1103. goto unapply_new_state;
  1104. /* Do not link hogs (circular dependency) */
  1105. if (p != setting->pctldev->p)
  1106. pinctrl_link_add(setting->pctldev, p->dev);
  1107. }
  1108. /* Apply all the settings for the new state - pinconf after */
  1109. list_for_each_entry(setting, &state->settings, node) {
  1110. switch (setting->type) {
  1111. case PIN_MAP_TYPE_MUX_GROUP:
  1112. ret = 0;
  1113. break;
  1114. case PIN_MAP_TYPE_CONFIGS_PIN:
  1115. case PIN_MAP_TYPE_CONFIGS_GROUP:
  1116. ret = pinconf_apply_setting(setting);
  1117. break;
  1118. default:
  1119. ret = -EINVAL;
  1120. break;
  1121. }
  1122. if (ret < 0) {
  1123. goto unapply_mux_setting;
  1124. }
  1125. /* Do not link hogs (circular dependency) */
  1126. if (p != setting->pctldev->p)
  1127. pinctrl_link_add(setting->pctldev, p->dev);
  1128. }
  1129. p->state = state;
  1130. return 0;
  1131. unapply_mux_setting:
  1132. pinctrl_cond_disable_mux_setting(state, NULL);
  1133. goto restore_old_state;
  1134. unapply_new_state:
  1135. dev_err(p->dev, "Error applying setting, reverse things back\n");
  1136. /*
  1137. * All we can do here is pinmux_disable_setting.
  1138. * That means that some pins are muxed differently now
  1139. * than they were before applying the setting (We can't
  1140. * "unmux a pin"!), but it's not a big deal since the pins
  1141. * are free to be muxed by another apply_setting.
  1142. */
  1143. pinctrl_cond_disable_mux_setting(state, setting);
  1144. restore_old_state:
  1145. /* There's no infinite recursive loop here because p->state is NULL */
  1146. if (old_state)
  1147. pinctrl_select_state(p, old_state);
  1148. return ret;
  1149. }
  1150. /**
  1151. * pinctrl_select_state() - select/activate/program a pinctrl state to HW
  1152. * @p: the pinctrl handle for the device that requests configuration
  1153. * @state: the state handle to select/activate/program
  1154. */
  1155. int pinctrl_select_state(struct pinctrl *p, struct pinctrl_state *state)
  1156. {
  1157. if (p->state == state)
  1158. return 0;
  1159. return pinctrl_commit_state(p, state);
  1160. }
  1161. EXPORT_SYMBOL_GPL(pinctrl_select_state);
  1162. static void devm_pinctrl_release(void *p)
  1163. {
  1164. pinctrl_put(p);
  1165. }
  1166. /**
  1167. * devm_pinctrl_get() - Resource managed pinctrl_get()
  1168. * @dev: the device to obtain the handle for
  1169. *
  1170. * If there is a need to explicitly destroy the returned struct pinctrl,
  1171. * devm_pinctrl_put() should be used, rather than plain pinctrl_put().
  1172. */
  1173. struct pinctrl *devm_pinctrl_get(struct device *dev)
  1174. {
  1175. struct pinctrl *p;
  1176. int ret;
  1177. p = pinctrl_get(dev);
  1178. if (IS_ERR(p))
  1179. return p;
  1180. ret = devm_add_action_or_reset(dev, devm_pinctrl_release, p);
  1181. if (ret)
  1182. return ERR_PTR(ret);
  1183. return p;
  1184. }
  1185. EXPORT_SYMBOL_GPL(devm_pinctrl_get);
  1186. /**
  1187. * devm_pinctrl_put() - Resource managed pinctrl_put()
  1188. * @p: the pinctrl handle to release
  1189. *
  1190. * Deallocate a struct pinctrl obtained via devm_pinctrl_get(). Normally
  1191. * this function will not need to be called and the resource management
  1192. * code will ensure that the resource is freed.
  1193. */
  1194. void devm_pinctrl_put(struct pinctrl *p)
  1195. {
  1196. devm_release_action(p->dev, devm_pinctrl_release, p);
  1197. }
  1198. EXPORT_SYMBOL_GPL(devm_pinctrl_put);
  1199. /**
  1200. * pinctrl_register_mappings() - register a set of pin controller mappings
  1201. * @maps: the pincontrol mappings table to register. Note the pinctrl-core
  1202. * keeps a reference to the passed in maps, so they should _not_ be
  1203. * marked with __initdata.
  1204. * @num_maps: the number of maps in the mapping table
  1205. */
  1206. int pinctrl_register_mappings(const struct pinctrl_map *maps,
  1207. unsigned int num_maps)
  1208. {
  1209. int i, ret;
  1210. struct pinctrl_maps *maps_node;
  1211. pr_debug("add %u pinctrl maps\n", num_maps);
  1212. /* First sanity check the new mapping */
  1213. for (i = 0; i < num_maps; i++) {
  1214. if (!maps[i].dev_name) {
  1215. pr_err("failed to register map %s (%d): no device given\n",
  1216. maps[i].name, i);
  1217. return -EINVAL;
  1218. }
  1219. if (!maps[i].name) {
  1220. pr_err("failed to register map %d: no map name given\n",
  1221. i);
  1222. return -EINVAL;
  1223. }
  1224. if (maps[i].type != PIN_MAP_TYPE_DUMMY_STATE &&
  1225. !maps[i].ctrl_dev_name) {
  1226. pr_err("failed to register map %s (%d): no pin control device given\n",
  1227. maps[i].name, i);
  1228. return -EINVAL;
  1229. }
  1230. switch (maps[i].type) {
  1231. case PIN_MAP_TYPE_DUMMY_STATE:
  1232. break;
  1233. case PIN_MAP_TYPE_MUX_GROUP:
  1234. ret = pinmux_validate_map(&maps[i], i);
  1235. if (ret < 0)
  1236. return ret;
  1237. break;
  1238. case PIN_MAP_TYPE_CONFIGS_PIN:
  1239. case PIN_MAP_TYPE_CONFIGS_GROUP:
  1240. ret = pinconf_validate_map(&maps[i], i);
  1241. if (ret < 0)
  1242. return ret;
  1243. break;
  1244. default:
  1245. pr_err("failed to register map %s (%d): invalid type given\n",
  1246. maps[i].name, i);
  1247. return -EINVAL;
  1248. }
  1249. }
  1250. maps_node = kzalloc_obj(*maps_node);
  1251. if (!maps_node)
  1252. return -ENOMEM;
  1253. maps_node->maps = maps;
  1254. maps_node->num_maps = num_maps;
  1255. mutex_lock(&pinctrl_maps_mutex);
  1256. list_add_tail(&maps_node->node, &pinctrl_maps);
  1257. mutex_unlock(&pinctrl_maps_mutex);
  1258. return 0;
  1259. }
  1260. EXPORT_SYMBOL_GPL(pinctrl_register_mappings);
  1261. /**
  1262. * pinctrl_unregister_mappings() - unregister a set of pin controller mappings
  1263. * @map: the pincontrol mappings table passed to pinctrl_register_mappings()
  1264. * when registering the mappings.
  1265. */
  1266. void pinctrl_unregister_mappings(const struct pinctrl_map *map)
  1267. {
  1268. struct pinctrl_maps *maps_node;
  1269. mutex_lock(&pinctrl_maps_mutex);
  1270. list_for_each_entry(maps_node, &pinctrl_maps, node) {
  1271. if (maps_node->maps == map) {
  1272. list_del(&maps_node->node);
  1273. kfree(maps_node);
  1274. mutex_unlock(&pinctrl_maps_mutex);
  1275. return;
  1276. }
  1277. }
  1278. mutex_unlock(&pinctrl_maps_mutex);
  1279. }
  1280. EXPORT_SYMBOL_GPL(pinctrl_unregister_mappings);
  1281. static void devm_pinctrl_unregister_mappings(void *maps)
  1282. {
  1283. pinctrl_unregister_mappings(maps);
  1284. }
  1285. /**
  1286. * devm_pinctrl_register_mappings() - Resource managed pinctrl_register_mappings()
  1287. * @dev: device for which mappings are registered
  1288. * @maps: the pincontrol mappings table to register. Note the pinctrl-core
  1289. * keeps a reference to the passed in maps, so they should _not_ be
  1290. * marked with __initdata.
  1291. * @num_maps: the number of maps in the mapping table
  1292. *
  1293. * Returns: 0 on success, or negative errno on failure.
  1294. */
  1295. int devm_pinctrl_register_mappings(struct device *dev,
  1296. const struct pinctrl_map *maps,
  1297. unsigned int num_maps)
  1298. {
  1299. int ret;
  1300. ret = pinctrl_register_mappings(maps, num_maps);
  1301. if (ret)
  1302. return ret;
  1303. return devm_add_action_or_reset(dev, devm_pinctrl_unregister_mappings, (void *)maps);
  1304. }
  1305. EXPORT_SYMBOL_GPL(devm_pinctrl_register_mappings);
  1306. /**
  1307. * pinctrl_force_sleep() - turn a given controller device into sleep state
  1308. * @pctldev: pin controller device
  1309. */
  1310. int pinctrl_force_sleep(struct pinctrl_dev *pctldev)
  1311. {
  1312. if (!IS_ERR(pctldev->p) && !IS_ERR(pctldev->hog_sleep))
  1313. return pinctrl_commit_state(pctldev->p, pctldev->hog_sleep);
  1314. return 0;
  1315. }
  1316. EXPORT_SYMBOL_GPL(pinctrl_force_sleep);
  1317. /**
  1318. * pinctrl_force_default() - turn a given controller device into default state
  1319. * @pctldev: pin controller device
  1320. */
  1321. int pinctrl_force_default(struct pinctrl_dev *pctldev)
  1322. {
  1323. if (!IS_ERR(pctldev->p) && !IS_ERR(pctldev->hog_default))
  1324. return pinctrl_commit_state(pctldev->p, pctldev->hog_default);
  1325. return 0;
  1326. }
  1327. EXPORT_SYMBOL_GPL(pinctrl_force_default);
  1328. /**
  1329. * pinctrl_init_done() - tell pinctrl probe is done
  1330. *
  1331. * We'll use this time to switch the pins from "init" to "default" unless the
  1332. * driver selected some other state.
  1333. *
  1334. * @dev: device to that's done probing
  1335. */
  1336. int pinctrl_init_done(struct device *dev)
  1337. {
  1338. struct dev_pin_info *pins = dev->pins;
  1339. int ret;
  1340. if (!pins)
  1341. return 0;
  1342. if (IS_ERR(pins->init_state))
  1343. return 0; /* No such state */
  1344. if (pins->p->state != pins->init_state)
  1345. return 0; /* Not at init anyway */
  1346. if (IS_ERR(pins->default_state))
  1347. return 0; /* No default state */
  1348. ret = pinctrl_select_state(pins->p, pins->default_state);
  1349. if (ret)
  1350. dev_err(dev, "failed to activate default pinctrl state\n");
  1351. return ret;
  1352. }
  1353. static int pinctrl_select_bound_state(struct device *dev,
  1354. struct pinctrl_state *state)
  1355. {
  1356. struct dev_pin_info *pins = dev->pins;
  1357. int ret;
  1358. if (IS_ERR(state))
  1359. return 0; /* No such state */
  1360. ret = pinctrl_select_state(pins->p, state);
  1361. if (ret)
  1362. dev_err(dev, "failed to activate pinctrl state %s\n",
  1363. state->name);
  1364. return ret;
  1365. }
  1366. /**
  1367. * pinctrl_select_default_state() - select default pinctrl state
  1368. * @dev: device to select default state for
  1369. */
  1370. int pinctrl_select_default_state(struct device *dev)
  1371. {
  1372. if (!dev->pins)
  1373. return 0;
  1374. return pinctrl_select_bound_state(dev, dev->pins->default_state);
  1375. }
  1376. EXPORT_SYMBOL_GPL(pinctrl_select_default_state);
  1377. #ifdef CONFIG_PM
  1378. /**
  1379. * pinctrl_pm_select_default_state() - select default pinctrl state for PM
  1380. * @dev: device to select default state for
  1381. */
  1382. int pinctrl_pm_select_default_state(struct device *dev)
  1383. {
  1384. return pinctrl_select_default_state(dev);
  1385. }
  1386. EXPORT_SYMBOL_GPL(pinctrl_pm_select_default_state);
  1387. /**
  1388. * pinctrl_pm_select_init_state() - select init pinctrl state for PM
  1389. * @dev: device to select init state for
  1390. */
  1391. int pinctrl_pm_select_init_state(struct device *dev)
  1392. {
  1393. if (!dev->pins)
  1394. return 0;
  1395. return pinctrl_select_bound_state(dev, dev->pins->init_state);
  1396. }
  1397. EXPORT_SYMBOL_GPL(pinctrl_pm_select_init_state);
  1398. /**
  1399. * pinctrl_pm_select_sleep_state() - select sleep pinctrl state for PM
  1400. * @dev: device to select sleep state for
  1401. */
  1402. int pinctrl_pm_select_sleep_state(struct device *dev)
  1403. {
  1404. if (!dev->pins)
  1405. return 0;
  1406. return pinctrl_select_bound_state(dev, dev->pins->sleep_state);
  1407. }
  1408. EXPORT_SYMBOL_GPL(pinctrl_pm_select_sleep_state);
  1409. /**
  1410. * pinctrl_pm_select_idle_state() - select idle pinctrl state for PM
  1411. * @dev: device to select idle state for
  1412. */
  1413. int pinctrl_pm_select_idle_state(struct device *dev)
  1414. {
  1415. if (!dev->pins)
  1416. return 0;
  1417. return pinctrl_select_bound_state(dev, dev->pins->idle_state);
  1418. }
  1419. EXPORT_SYMBOL_GPL(pinctrl_pm_select_idle_state);
  1420. #endif
  1421. #ifdef CONFIG_DEBUG_FS
  1422. static int pinctrl_pins_show(struct seq_file *s, void *what)
  1423. {
  1424. struct pinctrl_dev *pctldev = s->private;
  1425. const struct pinctrl_ops *ops = pctldev->desc->pctlops;
  1426. unsigned int i, pin;
  1427. #ifdef CONFIG_GPIOLIB
  1428. struct gpio_device *gdev = NULL;
  1429. struct pinctrl_gpio_range *range;
  1430. int gpio_num;
  1431. #endif
  1432. seq_printf(s, "registered pins: %d\n", pctldev->desc->npins);
  1433. mutex_lock(&pctldev->mutex);
  1434. /* The pin number can be retrived from the pin controller descriptor */
  1435. for (i = 0; i < pctldev->desc->npins; i++) {
  1436. struct pin_desc *desc;
  1437. pin = pctldev->desc->pins[i].number;
  1438. desc = pin_desc_get(pctldev, pin);
  1439. /* Pin space may be sparse */
  1440. if (!desc)
  1441. continue;
  1442. seq_printf(s, "pin %d (%s) ", pin, desc->name);
  1443. #ifdef CONFIG_GPIOLIB
  1444. gdev = NULL;
  1445. gpio_num = -1;
  1446. list_for_each_entry(range, &pctldev->gpio_ranges, node) {
  1447. if (range->pins != NULL) {
  1448. for (int i = 0; i < range->npins; ++i) {
  1449. if (range->pins[i] == pin) {
  1450. gpio_num = range->base + i;
  1451. break;
  1452. }
  1453. }
  1454. } else if ((pin >= range->pin_base) &&
  1455. (pin < (range->pin_base + range->npins))) {
  1456. gpio_num =
  1457. range->base + (pin - range->pin_base);
  1458. }
  1459. if (gpio_num != -1)
  1460. break;
  1461. }
  1462. if (gpio_num >= 0)
  1463. /*
  1464. * FIXME: gpio_num comes from the global GPIO numberspace.
  1465. * we need to get rid of the range->base eventually and
  1466. * get the descriptor directly from the gpio_chip.
  1467. */
  1468. gdev = gpiod_to_gpio_device(gpio_to_desc(gpio_num));
  1469. if (gdev)
  1470. seq_printf(s, "%u:%s ",
  1471. gpio_num - gpio_device_get_base(gdev),
  1472. gpio_device_get_label(gdev));
  1473. else
  1474. seq_puts(s, "0:? ");
  1475. #endif
  1476. /* Driver-specific info per pin */
  1477. if (ops->pin_dbg_show)
  1478. ops->pin_dbg_show(pctldev, s, pin);
  1479. seq_puts(s, "\n");
  1480. }
  1481. mutex_unlock(&pctldev->mutex);
  1482. return 0;
  1483. }
  1484. DEFINE_SHOW_ATTRIBUTE(pinctrl_pins);
  1485. static int pinctrl_groups_show(struct seq_file *s, void *what)
  1486. {
  1487. struct pinctrl_dev *pctldev = s->private;
  1488. const struct pinctrl_ops *ops = pctldev->desc->pctlops;
  1489. unsigned int ngroups, selector = 0;
  1490. mutex_lock(&pctldev->mutex);
  1491. ngroups = ops->get_groups_count(pctldev);
  1492. seq_puts(s, "registered pin groups:\n");
  1493. while (selector < ngroups) {
  1494. const unsigned int *pins = NULL;
  1495. unsigned int num_pins = 0;
  1496. const char *gname = ops->get_group_name(pctldev, selector);
  1497. const char *pname;
  1498. int ret = 0;
  1499. int i;
  1500. if (ops->get_group_pins)
  1501. ret = ops->get_group_pins(pctldev, selector,
  1502. &pins, &num_pins);
  1503. if (ret)
  1504. seq_printf(s, "%s [ERROR GETTING PINS]\n",
  1505. gname);
  1506. else {
  1507. seq_printf(s, "group: %s\n", gname);
  1508. for (i = 0; i < num_pins; i++) {
  1509. pname = pin_get_name(pctldev, pins[i]);
  1510. if (WARN_ON(!pname)) {
  1511. mutex_unlock(&pctldev->mutex);
  1512. return -EINVAL;
  1513. }
  1514. seq_printf(s, "pin %d (%s)\n", pins[i], pname);
  1515. }
  1516. seq_puts(s, "\n");
  1517. }
  1518. selector++;
  1519. }
  1520. mutex_unlock(&pctldev->mutex);
  1521. return 0;
  1522. }
  1523. DEFINE_SHOW_ATTRIBUTE(pinctrl_groups);
  1524. static int pinctrl_gpioranges_show(struct seq_file *s, void *what)
  1525. {
  1526. struct pinctrl_dev *pctldev = s->private;
  1527. struct pinctrl_gpio_range *range;
  1528. seq_puts(s, "GPIO ranges handled:\n");
  1529. mutex_lock(&pctldev->mutex);
  1530. /* Loop over the ranges */
  1531. list_for_each_entry(range, &pctldev->gpio_ranges, node) {
  1532. if (range->pins) {
  1533. int a;
  1534. seq_printf(s, "%u: %s GPIOS [%u - %u] PINS {",
  1535. range->id, range->name,
  1536. range->base, (range->base + range->npins - 1));
  1537. for (a = 0; a < range->npins - 1; a++)
  1538. seq_printf(s, "%u, ", range->pins[a]);
  1539. seq_printf(s, "%u}\n", range->pins[a]);
  1540. }
  1541. else
  1542. seq_printf(s, "%u: %s GPIOS [%u - %u] PINS [%u - %u]\n",
  1543. range->id, range->name,
  1544. range->base, (range->base + range->npins - 1),
  1545. range->pin_base,
  1546. (range->pin_base + range->npins - 1));
  1547. }
  1548. mutex_unlock(&pctldev->mutex);
  1549. return 0;
  1550. }
  1551. DEFINE_SHOW_ATTRIBUTE(pinctrl_gpioranges);
  1552. static int pinctrl_devices_show(struct seq_file *s, void *what)
  1553. {
  1554. struct pinctrl_dev *pctldev;
  1555. seq_puts(s, "name [pinmux] [pinconf]\n");
  1556. mutex_lock(&pinctrldev_list_mutex);
  1557. list_for_each_entry(pctldev, &pinctrldev_list, node) {
  1558. seq_printf(s, "%s ", pctldev->desc->name);
  1559. if (pctldev->desc->pmxops)
  1560. seq_puts(s, "yes ");
  1561. else
  1562. seq_puts(s, "no ");
  1563. if (pctldev->desc->confops)
  1564. seq_puts(s, "yes");
  1565. else
  1566. seq_puts(s, "no");
  1567. seq_puts(s, "\n");
  1568. }
  1569. mutex_unlock(&pinctrldev_list_mutex);
  1570. return 0;
  1571. }
  1572. DEFINE_SHOW_ATTRIBUTE(pinctrl_devices);
  1573. static inline const char *map_type(enum pinctrl_map_type type)
  1574. {
  1575. static const char * const names[] = {
  1576. "INVALID",
  1577. "DUMMY_STATE",
  1578. "MUX_GROUP",
  1579. "CONFIGS_PIN",
  1580. "CONFIGS_GROUP",
  1581. };
  1582. if (type >= ARRAY_SIZE(names))
  1583. return "UNKNOWN";
  1584. return names[type];
  1585. }
  1586. static int pinctrl_maps_show(struct seq_file *s, void *what)
  1587. {
  1588. struct pinctrl_maps *maps_node;
  1589. const struct pinctrl_map *map;
  1590. seq_puts(s, "Pinctrl maps:\n");
  1591. mutex_lock(&pinctrl_maps_mutex);
  1592. for_each_pin_map(maps_node, map) {
  1593. seq_printf(s, "device %s\nstate %s\ntype %s (%d)\n",
  1594. map->dev_name, map->name, map_type(map->type),
  1595. map->type);
  1596. if (map->type != PIN_MAP_TYPE_DUMMY_STATE)
  1597. seq_printf(s, "controlling device %s\n",
  1598. map->ctrl_dev_name);
  1599. switch (map->type) {
  1600. case PIN_MAP_TYPE_MUX_GROUP:
  1601. pinmux_show_map(s, map);
  1602. break;
  1603. case PIN_MAP_TYPE_CONFIGS_PIN:
  1604. case PIN_MAP_TYPE_CONFIGS_GROUP:
  1605. pinconf_show_map(s, map);
  1606. break;
  1607. default:
  1608. break;
  1609. }
  1610. seq_putc(s, '\n');
  1611. }
  1612. mutex_unlock(&pinctrl_maps_mutex);
  1613. return 0;
  1614. }
  1615. DEFINE_SHOW_ATTRIBUTE(pinctrl_maps);
  1616. static int pinctrl_show(struct seq_file *s, void *what)
  1617. {
  1618. struct pinctrl *p;
  1619. struct pinctrl_state *state;
  1620. struct pinctrl_setting *setting;
  1621. seq_puts(s, "Requested pin control handlers their pinmux maps:\n");
  1622. mutex_lock(&pinctrl_list_mutex);
  1623. list_for_each_entry(p, &pinctrl_list, node) {
  1624. seq_printf(s, "device: %s current state: %s\n",
  1625. dev_name(p->dev),
  1626. p->state ? p->state->name : "none");
  1627. list_for_each_entry(state, &p->states, node) {
  1628. seq_printf(s, " state: %s\n", state->name);
  1629. list_for_each_entry(setting, &state->settings, node) {
  1630. struct pinctrl_dev *pctldev = setting->pctldev;
  1631. seq_printf(s, " type: %s controller %s ",
  1632. map_type(setting->type),
  1633. pinctrl_dev_get_name(pctldev));
  1634. switch (setting->type) {
  1635. case PIN_MAP_TYPE_MUX_GROUP:
  1636. pinmux_show_setting(s, setting);
  1637. break;
  1638. case PIN_MAP_TYPE_CONFIGS_PIN:
  1639. case PIN_MAP_TYPE_CONFIGS_GROUP:
  1640. pinconf_show_setting(s, setting);
  1641. break;
  1642. default:
  1643. break;
  1644. }
  1645. }
  1646. }
  1647. }
  1648. mutex_unlock(&pinctrl_list_mutex);
  1649. return 0;
  1650. }
  1651. DEFINE_SHOW_ATTRIBUTE(pinctrl);
  1652. static struct dentry *debugfs_root;
  1653. static void pinctrl_init_device_debugfs(struct pinctrl_dev *pctldev)
  1654. {
  1655. struct dentry *device_root;
  1656. const char *debugfs_name;
  1657. if (pctldev->desc->name &&
  1658. strcmp(dev_name(pctldev->dev), pctldev->desc->name)) {
  1659. debugfs_name = devm_kasprintf(pctldev->dev, GFP_KERNEL,
  1660. "%s-%s", dev_name(pctldev->dev),
  1661. pctldev->desc->name);
  1662. if (!debugfs_name) {
  1663. pr_warn("failed to determine debugfs dir name for %s\n",
  1664. dev_name(pctldev->dev));
  1665. return;
  1666. }
  1667. } else {
  1668. debugfs_name = dev_name(pctldev->dev);
  1669. }
  1670. device_root = debugfs_create_dir(debugfs_name, debugfs_root);
  1671. pctldev->device_root = device_root;
  1672. if (IS_ERR(device_root) || !device_root) {
  1673. pr_warn("failed to create debugfs directory for %s\n",
  1674. dev_name(pctldev->dev));
  1675. return;
  1676. }
  1677. debugfs_create_file("pins", 0444,
  1678. device_root, pctldev, &pinctrl_pins_fops);
  1679. debugfs_create_file("pingroups", 0444,
  1680. device_root, pctldev, &pinctrl_groups_fops);
  1681. debugfs_create_file("gpio-ranges", 0444,
  1682. device_root, pctldev, &pinctrl_gpioranges_fops);
  1683. if (pctldev->desc->pmxops)
  1684. pinmux_init_device_debugfs(device_root, pctldev);
  1685. if (pctldev->desc->confops)
  1686. pinconf_init_device_debugfs(device_root, pctldev);
  1687. }
  1688. static void pinctrl_remove_device_debugfs(struct pinctrl_dev *pctldev)
  1689. {
  1690. debugfs_remove_recursive(pctldev->device_root);
  1691. }
  1692. static void pinctrl_init_debugfs(void)
  1693. {
  1694. debugfs_root = debugfs_create_dir("pinctrl", NULL);
  1695. if (IS_ERR(debugfs_root)) {
  1696. pr_warn("failed to create debugfs directory\n");
  1697. debugfs_root = NULL;
  1698. return;
  1699. }
  1700. debugfs_create_file("pinctrl-devices", 0444,
  1701. debugfs_root, NULL, &pinctrl_devices_fops);
  1702. debugfs_create_file("pinctrl-maps", 0444,
  1703. debugfs_root, NULL, &pinctrl_maps_fops);
  1704. debugfs_create_file("pinctrl-handles", 0444,
  1705. debugfs_root, NULL, &pinctrl_fops);
  1706. }
  1707. #else /* CONFIG_DEBUG_FS */
  1708. static void pinctrl_init_device_debugfs(struct pinctrl_dev *pctldev)
  1709. {
  1710. }
  1711. static void pinctrl_init_debugfs(void)
  1712. {
  1713. }
  1714. static void pinctrl_remove_device_debugfs(struct pinctrl_dev *pctldev)
  1715. {
  1716. }
  1717. #endif
  1718. static int pinctrl_check_ops(struct pinctrl_dev *pctldev)
  1719. {
  1720. const struct pinctrl_ops *ops = pctldev->desc->pctlops;
  1721. if (!ops ||
  1722. !ops->get_groups_count ||
  1723. !ops->get_group_name)
  1724. return -EINVAL;
  1725. return 0;
  1726. }
  1727. /**
  1728. * pinctrl_init_controller() - init a pin controller device
  1729. * @pctldesc: descriptor for this pin controller
  1730. * @dev: parent device for this pin controller
  1731. * @driver_data: private pin controller data for this pin controller
  1732. */
  1733. static struct pinctrl_dev *
  1734. pinctrl_init_controller(const struct pinctrl_desc *pctldesc, struct device *dev,
  1735. void *driver_data)
  1736. {
  1737. struct pinctrl_dev *pctldev;
  1738. int ret;
  1739. if (!pctldesc)
  1740. return ERR_PTR(-EINVAL);
  1741. if (!pctldesc->name)
  1742. return ERR_PTR(-EINVAL);
  1743. pctldev = kzalloc_obj(*pctldev);
  1744. if (!pctldev)
  1745. return ERR_PTR(-ENOMEM);
  1746. /* Initialize pin control device struct */
  1747. pctldev->owner = pctldesc->owner;
  1748. pctldev->desc = pctldesc;
  1749. pctldev->driver_data = driver_data;
  1750. INIT_RADIX_TREE(&pctldev->pin_desc_tree, GFP_KERNEL);
  1751. #ifdef CONFIG_GENERIC_PINCTRL_GROUPS
  1752. INIT_RADIX_TREE(&pctldev->pin_group_tree, GFP_KERNEL);
  1753. #endif
  1754. #ifdef CONFIG_GENERIC_PINMUX_FUNCTIONS
  1755. INIT_RADIX_TREE(&pctldev->pin_function_tree, GFP_KERNEL);
  1756. #endif
  1757. INIT_LIST_HEAD(&pctldev->gpio_ranges);
  1758. INIT_LIST_HEAD(&pctldev->node);
  1759. pctldev->dev = dev;
  1760. mutex_init(&pctldev->mutex);
  1761. /* check core ops for sanity */
  1762. ret = pinctrl_check_ops(pctldev);
  1763. if (ret) {
  1764. dev_err(dev, "pinctrl ops lacks necessary functions\n");
  1765. goto out_err;
  1766. }
  1767. /* If we're implementing pinmuxing, check the ops for sanity */
  1768. if (pctldesc->pmxops) {
  1769. ret = pinmux_check_ops(pctldev);
  1770. if (ret)
  1771. goto out_err;
  1772. }
  1773. /* If we're implementing pinconfig, check the ops for sanity */
  1774. if (pctldesc->confops) {
  1775. ret = pinconf_check_ops(pctldev);
  1776. if (ret)
  1777. goto out_err;
  1778. }
  1779. /* Register all the pins */
  1780. dev_dbg(dev, "try to register %d pins ...\n", pctldesc->npins);
  1781. ret = pinctrl_register_pins(pctldev, pctldesc->pins, pctldesc->npins);
  1782. if (ret) {
  1783. dev_err(dev, "error during pin registration\n");
  1784. pinctrl_free_pindescs(pctldev, pctldesc->pins,
  1785. pctldesc->npins);
  1786. goto out_err;
  1787. }
  1788. return pctldev;
  1789. out_err:
  1790. mutex_destroy(&pctldev->mutex);
  1791. kfree(pctldev);
  1792. return ERR_PTR(ret);
  1793. }
  1794. static void pinctrl_uninit_controller(struct pinctrl_dev *pctldev,
  1795. const struct pinctrl_desc *pctldesc)
  1796. {
  1797. pinctrl_free_pindescs(pctldev, pctldesc->pins,
  1798. pctldesc->npins);
  1799. mutex_destroy(&pctldev->mutex);
  1800. kfree(pctldev);
  1801. }
  1802. static int pinctrl_claim_hogs(struct pinctrl_dev *pctldev)
  1803. {
  1804. pctldev->p = create_pinctrl(pctldev->dev, pctldev);
  1805. if (PTR_ERR(pctldev->p) == -ENODEV) {
  1806. dev_dbg(pctldev->dev, "no hogs found\n");
  1807. return 0;
  1808. }
  1809. if (IS_ERR(pctldev->p)) {
  1810. dev_err(pctldev->dev, "error claiming hogs: %li\n",
  1811. PTR_ERR(pctldev->p));
  1812. return PTR_ERR(pctldev->p);
  1813. }
  1814. pctldev->hog_default =
  1815. pinctrl_lookup_state(pctldev->p, PINCTRL_STATE_DEFAULT);
  1816. if (IS_ERR(pctldev->hog_default)) {
  1817. dev_dbg(pctldev->dev,
  1818. "failed to lookup the default state\n");
  1819. } else {
  1820. if (pinctrl_select_state(pctldev->p,
  1821. pctldev->hog_default))
  1822. dev_err(pctldev->dev,
  1823. "failed to select default state\n");
  1824. }
  1825. pctldev->hog_sleep =
  1826. pinctrl_lookup_state(pctldev->p,
  1827. PINCTRL_STATE_SLEEP);
  1828. if (IS_ERR(pctldev->hog_sleep))
  1829. dev_dbg(pctldev->dev,
  1830. "failed to lookup the sleep state\n");
  1831. return 0;
  1832. }
  1833. int pinctrl_enable(struct pinctrl_dev *pctldev)
  1834. {
  1835. int error;
  1836. error = pinctrl_claim_hogs(pctldev);
  1837. if (error)
  1838. return error;
  1839. mutex_lock(&pinctrldev_list_mutex);
  1840. list_add_tail(&pctldev->node, &pinctrldev_list);
  1841. mutex_unlock(&pinctrldev_list_mutex);
  1842. pinctrl_init_device_debugfs(pctldev);
  1843. return 0;
  1844. }
  1845. EXPORT_SYMBOL_GPL(pinctrl_enable);
  1846. /**
  1847. * pinctrl_register() - register a pin controller device
  1848. * @pctldesc: descriptor for this pin controller
  1849. * @dev: parent device for this pin controller
  1850. * @driver_data: private pin controller data for this pin controller
  1851. *
  1852. * Note that pinctrl_register() is known to have problems as the pin
  1853. * controller driver functions are called before the driver has a
  1854. * struct pinctrl_dev handle. To avoid issues later on, please use the
  1855. * new pinctrl_register_and_init() below instead.
  1856. */
  1857. struct pinctrl_dev *pinctrl_register(const struct pinctrl_desc *pctldesc,
  1858. struct device *dev, void *driver_data)
  1859. {
  1860. struct pinctrl_dev *pctldev;
  1861. int error;
  1862. pctldev = pinctrl_init_controller(pctldesc, dev, driver_data);
  1863. if (IS_ERR(pctldev))
  1864. return pctldev;
  1865. error = pinctrl_enable(pctldev);
  1866. if (error) {
  1867. pinctrl_uninit_controller(pctldev, pctldesc);
  1868. return ERR_PTR(error);
  1869. }
  1870. return pctldev;
  1871. }
  1872. EXPORT_SYMBOL_GPL(pinctrl_register);
  1873. /**
  1874. * pinctrl_register_and_init() - register and init pin controller device
  1875. * @pctldesc: descriptor for this pin controller
  1876. * @dev: parent device for this pin controller
  1877. * @driver_data: private pin controller data for this pin controller
  1878. * @pctldev: pin controller device
  1879. *
  1880. * Note that pinctrl_enable() still needs to be manually called after
  1881. * this once the driver is ready.
  1882. */
  1883. int pinctrl_register_and_init(const struct pinctrl_desc *pctldesc,
  1884. struct device *dev, void *driver_data,
  1885. struct pinctrl_dev **pctldev)
  1886. {
  1887. struct pinctrl_dev *p;
  1888. p = pinctrl_init_controller(pctldesc, dev, driver_data);
  1889. if (IS_ERR(p))
  1890. return PTR_ERR(p);
  1891. /*
  1892. * We have pinctrl_start() call functions in the pin controller
  1893. * driver with create_pinctrl() for at least dt_node_to_map(). So
  1894. * let's make sure pctldev is properly initialized for the
  1895. * pin controller driver before we do anything.
  1896. */
  1897. *pctldev = p;
  1898. return 0;
  1899. }
  1900. EXPORT_SYMBOL_GPL(pinctrl_register_and_init);
  1901. /**
  1902. * pinctrl_unregister() - unregister pinmux
  1903. * @pctldev: pin controller to unregister
  1904. *
  1905. * Called by pinmux drivers to unregister a pinmux.
  1906. */
  1907. void pinctrl_unregister(struct pinctrl_dev *pctldev)
  1908. {
  1909. struct pinctrl_gpio_range *range, *n;
  1910. if (!pctldev)
  1911. return;
  1912. mutex_lock(&pctldev->mutex);
  1913. pinctrl_remove_device_debugfs(pctldev);
  1914. mutex_unlock(&pctldev->mutex);
  1915. if (!IS_ERR_OR_NULL(pctldev->p))
  1916. pinctrl_put(pctldev->p);
  1917. mutex_lock(&pinctrldev_list_mutex);
  1918. mutex_lock(&pctldev->mutex);
  1919. /* TODO: check that no pinmuxes are still active? */
  1920. list_del(&pctldev->node);
  1921. pinmux_generic_free_functions(pctldev);
  1922. pinctrl_generic_free_groups(pctldev);
  1923. /* Destroy descriptor tree */
  1924. pinctrl_free_pindescs(pctldev, pctldev->desc->pins,
  1925. pctldev->desc->npins);
  1926. /* remove gpio ranges map */
  1927. list_for_each_entry_safe(range, n, &pctldev->gpio_ranges, node)
  1928. list_del(&range->node);
  1929. mutex_unlock(&pctldev->mutex);
  1930. mutex_destroy(&pctldev->mutex);
  1931. kfree(pctldev);
  1932. mutex_unlock(&pinctrldev_list_mutex);
  1933. }
  1934. EXPORT_SYMBOL_GPL(pinctrl_unregister);
  1935. static void devm_pinctrl_dev_release(void *pctldev)
  1936. {
  1937. pinctrl_unregister(pctldev);
  1938. }
  1939. /**
  1940. * devm_pinctrl_register() - Resource managed version of pinctrl_register().
  1941. * @dev: parent device for this pin controller
  1942. * @pctldesc: descriptor for this pin controller
  1943. * @driver_data: private pin controller data for this pin controller
  1944. *
  1945. * Returns an error pointer if pincontrol register failed. Otherwise
  1946. * it returns valid pinctrl handle.
  1947. *
  1948. * The pinctrl device will be automatically released when the device is unbound.
  1949. */
  1950. struct pinctrl_dev *devm_pinctrl_register(struct device *dev,
  1951. const struct pinctrl_desc *pctldesc,
  1952. void *driver_data)
  1953. {
  1954. struct pinctrl_dev *pctldev;
  1955. int ret;
  1956. pctldev = pinctrl_register(pctldesc, dev, driver_data);
  1957. if (IS_ERR(pctldev))
  1958. return pctldev;
  1959. ret = devm_add_action_or_reset(dev, devm_pinctrl_dev_release, pctldev);
  1960. if (ret)
  1961. return ERR_PTR(ret);
  1962. return pctldev;
  1963. }
  1964. EXPORT_SYMBOL_GPL(devm_pinctrl_register);
  1965. /**
  1966. * devm_pinctrl_register_and_init() - Resource managed pinctrl register and init
  1967. * @dev: parent device for this pin controller
  1968. * @pctldesc: descriptor for this pin controller
  1969. * @driver_data: private pin controller data for this pin controller
  1970. * @pctldev: pin controller device
  1971. *
  1972. * Returns zero on success or an error number on failure.
  1973. *
  1974. * The pinctrl device will be automatically released when the device is unbound.
  1975. */
  1976. int devm_pinctrl_register_and_init(struct device *dev,
  1977. const struct pinctrl_desc *pctldesc,
  1978. void *driver_data,
  1979. struct pinctrl_dev **pctldev)
  1980. {
  1981. int error;
  1982. error = pinctrl_register_and_init(pctldesc, dev, driver_data, pctldev);
  1983. if (error)
  1984. return error;
  1985. return devm_add_action_or_reset(dev, devm_pinctrl_dev_release, *pctldev);
  1986. }
  1987. EXPORT_SYMBOL_GPL(devm_pinctrl_register_and_init);
  1988. static int __init pinctrl_init(void)
  1989. {
  1990. pr_debug("initialized pinctrl subsystem\n");
  1991. pinctrl_init_debugfs();
  1992. return 0;
  1993. }
  1994. /* init early since many drivers really need to initialized pinmux early */
  1995. core_initcall(pinctrl_init);