1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * at91 pinctrl driver based on at91 pinmux core 4 * 5 * Copyright (C) 2011-2012 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> 6 */ 7 8 #include <linux/clk.h> 9 #include <linux/err.h> 10 #include <linux/gpio/driver.h> 11 #include <linux/init.h> 12 #include <linux/interrupt.h> 13 #include <linux/io.h> 14 #include <linux/of.h> 15 #include <linux/of_address.h> 16 #include <linux/of_device.h> 17 #include <linux/of_irq.h> 18 #include <linux/pm.h> 19 #include <linux/seq_file.h> 20 #include <linux/slab.h> 21 #include <linux/string_helpers.h> 22 23 /* Since we request GPIOs from ourself */ 24 #include <linux/pinctrl/consumer.h> 25 #include <linux/pinctrl/machine.h> 26 #include <linux/pinctrl/pinconf.h> 27 #include <linux/pinctrl/pinctrl.h> 28 #include <linux/pinctrl/pinmux.h> 29 30 #include "pinctrl-at91.h" 31 #include "core.h" 32 33 #define MAX_GPIO_BANKS 5 34 #define MAX_NB_GPIO_PER_BANK 32 35 36 struct at91_pinctrl_mux_ops; 37 38 /** 39 * struct at91_gpio_chip: at91 gpio chip 40 * @chip: gpio chip 41 * @range: gpio range 42 * @next: bank sharing same clock 43 * @pioc_hwirq: PIO bank interrupt identifier on AIC 44 * @pioc_virq: PIO bank Linux virtual interrupt 45 * @regbase: PIO bank virtual address 46 * @clock: associated clock 47 * @ops: at91 pinctrl mux ops 48 * @wakeups: wakeup interrupts 49 * @backups: interrupts disabled in suspend 50 * @id: gpio chip identifier 51 */ 52 struct at91_gpio_chip { 53 struct gpio_chip chip; 54 struct pinctrl_gpio_range range; 55 struct at91_gpio_chip *next; 56 int pioc_hwirq; 57 int pioc_virq; 58 void __iomem *regbase; 59 struct clk *clock; 60 const struct at91_pinctrl_mux_ops *ops; 61 u32 wakeups; 62 u32 backups; 63 u32 id; 64 }; 65 66 static struct at91_gpio_chip *gpio_chips[MAX_GPIO_BANKS]; 67 68 static int gpio_banks; 69 70 #define PULL_UP (1 << 0) 71 #define MULTI_DRIVE (1 << 1) 72 #define DEGLITCH (1 << 2) 73 #define PULL_DOWN (1 << 3) 74 #define DIS_SCHMIT (1 << 4) 75 #define DRIVE_STRENGTH_SHIFT 5 76 #define DRIVE_STRENGTH_MASK 0x3 77 #define DRIVE_STRENGTH (DRIVE_STRENGTH_MASK << DRIVE_STRENGTH_SHIFT) 78 #define OUTPUT (1 << 7) 79 #define OUTPUT_VAL_SHIFT 8 80 #define OUTPUT_VAL (0x1 << OUTPUT_VAL_SHIFT) 81 #define SLEWRATE_SHIFT 9 82 #define SLEWRATE_MASK 0x1 83 #define SLEWRATE (SLEWRATE_MASK << SLEWRATE_SHIFT) 84 #define DEBOUNCE (1 << 16) 85 #define DEBOUNCE_VAL_SHIFT 17 86 #define DEBOUNCE_VAL (0x3fff << DEBOUNCE_VAL_SHIFT) 87 88 /* 89 * These defines will translated the dt binding settings to our internal 90 * settings. They are not necessarily the same value as the register setting. 91 * The actual drive strength current of low, medium and high must be looked up 92 * from the corresponding device datasheet. This value is different for pins 93 * that are even in the same banks. It is also dependent on VCC. 94 * DRIVE_STRENGTH_DEFAULT is just a placeholder to avoid changing the drive 95 * strength when there is no dt config for it. 96 */ 97 enum drive_strength_bit { 98 DRIVE_STRENGTH_BIT_DEF, 99 DRIVE_STRENGTH_BIT_LOW, 100 DRIVE_STRENGTH_BIT_MED, 101 DRIVE_STRENGTH_BIT_HI, 102 }; 103 104 #define DRIVE_STRENGTH_BIT_MSK(name) (DRIVE_STRENGTH_BIT_##name << \ 105 DRIVE_STRENGTH_SHIFT) 106 107 enum slewrate_bit { 108 SLEWRATE_BIT_ENA, 109 SLEWRATE_BIT_DIS, 110 }; 111 112 #define SLEWRATE_BIT_MSK(name) (SLEWRATE_BIT_##name << SLEWRATE_SHIFT) 113 114 /** 115 * struct at91_pmx_func - describes AT91 pinmux functions 116 * @name: the name of this specific function 117 * @groups: corresponding pin groups 118 * @ngroups: the number of groups 119 */ 120 struct at91_pmx_func { 121 const char *name; 122 const char **groups; 123 unsigned ngroups; 124 }; 125 126 enum at91_mux { 127 AT91_MUX_GPIO = 0, 128 AT91_MUX_PERIPH_A = 1, 129 AT91_MUX_PERIPH_B = 2, 130 AT91_MUX_PERIPH_C = 3, 131 AT91_MUX_PERIPH_D = 4, 132 }; 133 134 /** 135 * struct at91_pmx_pin - describes an At91 pin mux 136 * @bank: the bank of the pin 137 * @pin: the pin number in the @bank 138 * @mux: the mux mode : gpio or periph_x of the pin i.e. alternate function. 139 * @conf: the configuration of the pin: PULL_UP, MULTIDRIVE etc... 140 */ 141 struct at91_pmx_pin { 142 uint32_t bank; 143 uint32_t pin; 144 enum at91_mux mux; 145 unsigned long conf; 146 }; 147 148 /** 149 * struct at91_pin_group - describes an At91 pin group 150 * @name: the name of this specific pin group 151 * @pins_conf: the mux mode for each pin in this group. The size of this 152 * array is the same as pins. 153 * @pins: an array of discrete physical pins used in this group, taken 154 * from the driver-local pin enumeration space 155 * @npins: the number of pins in this group array, i.e. the number of 156 * elements in .pins so we can iterate over that array 157 */ 158 struct at91_pin_group { 159 const char *name; 160 struct at91_pmx_pin *pins_conf; 161 unsigned int *pins; 162 unsigned npins; 163 }; 164 165 /** 166 * struct at91_pinctrl_mux_ops - describes an AT91 mux ops group 167 * on new IP with support for periph C and D the way to mux in 168 * periph A and B has changed 169 * So provide the right call back 170 * if not present means the IP does not support it 171 * @get_periph: return the periph mode configured 172 * @mux_A_periph: mux as periph A 173 * @mux_B_periph: mux as periph B 174 * @mux_C_periph: mux as periph C 175 * @mux_D_periph: mux as periph D 176 * @get_deglitch: get deglitch status 177 * @set_deglitch: enable/disable deglitch 178 * @get_debounce: get debounce status 179 * @set_debounce: enable/disable debounce 180 * @get_pulldown: get pulldown status 181 * @set_pulldown: enable/disable pulldown 182 * @get_schmitt_trig: get schmitt trigger status 183 * @disable_schmitt_trig: disable schmitt trigger 184 * @get_drivestrength: get driver strength 185 * @set_drivestrength: set driver strength 186 * @get_slewrate: get slew rate 187 * @set_slewrate: set slew rate 188 * @irq_type: return irq type 189 */ 190 struct at91_pinctrl_mux_ops { 191 enum at91_mux (*get_periph)(void __iomem *pio, unsigned mask); 192 void (*mux_A_periph)(void __iomem *pio, unsigned mask); 193 void (*mux_B_periph)(void __iomem *pio, unsigned mask); 194 void (*mux_C_periph)(void __iomem *pio, unsigned mask); 195 void (*mux_D_periph)(void __iomem *pio, unsigned mask); 196 bool (*get_deglitch)(void __iomem *pio, unsigned pin); 197 void (*set_deglitch)(void __iomem *pio, unsigned mask, bool is_on); 198 bool (*get_debounce)(void __iomem *pio, unsigned pin, u32 *div); 199 void (*set_debounce)(void __iomem *pio, unsigned mask, bool is_on, u32 div); 200 bool (*get_pulldown)(void __iomem *pio, unsigned pin); 201 void (*set_pulldown)(void __iomem *pio, unsigned mask, bool is_on); 202 bool (*get_schmitt_trig)(void __iomem *pio, unsigned pin); 203 void (*disable_schmitt_trig)(void __iomem *pio, unsigned mask); 204 unsigned (*get_drivestrength)(void __iomem *pio, unsigned pin); 205 void (*set_drivestrength)(void __iomem *pio, unsigned pin, 206 u32 strength); 207 unsigned (*get_slewrate)(void __iomem *pio, unsigned pin); 208 void (*set_slewrate)(void __iomem *pio, unsigned pin, u32 slewrate); 209 /* irq */ 210 int (*irq_type)(struct irq_data *d, unsigned type); 211 }; 212 213 static int gpio_irq_type(struct irq_data *d, unsigned type); 214 static int alt_gpio_irq_type(struct irq_data *d, unsigned type); 215 216 struct at91_pinctrl { 217 struct device *dev; 218 struct pinctrl_dev *pctl; 219 220 int nactive_banks; 221 222 uint32_t *mux_mask; 223 int nmux; 224 225 struct at91_pmx_func *functions; 226 int nfunctions; 227 228 struct at91_pin_group *groups; 229 int ngroups; 230 231 const struct at91_pinctrl_mux_ops *ops; 232 }; 233 234 static inline const struct at91_pin_group *at91_pinctrl_find_group_by_name( 235 const struct at91_pinctrl *info, 236 const char *name) 237 { 238 const struct at91_pin_group *grp = NULL; 239 int i; 240 241 for (i = 0; i < info->ngroups; i++) { 242 if (strcmp(info->groups[i].name, name)) 243 continue; 244 245 grp = &info->groups[i]; 246 dev_dbg(info->dev, "%s: %d 0:%d\n", name, grp->npins, grp->pins[0]); 247 break; 248 } 249 250 return grp; 251 } 252 253 static int at91_get_groups_count(struct pinctrl_dev *pctldev) 254 { 255 struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); 256 257 return info->ngroups; 258 } 259 260 static const char *at91_get_group_name(struct pinctrl_dev *pctldev, 261 unsigned selector) 262 { 263 struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); 264 265 return info->groups[selector].name; 266 } 267 268 static int at91_get_group_pins(struct pinctrl_dev *pctldev, unsigned selector, 269 const unsigned **pins, 270 unsigned *npins) 271 { 272 struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); 273 274 if (selector >= info->ngroups) 275 return -EINVAL; 276 277 *pins = info->groups[selector].pins; 278 *npins = info->groups[selector].npins; 279 280 return 0; 281 } 282 283 static void at91_pin_dbg_show(struct pinctrl_dev *pctldev, struct seq_file *s, 284 unsigned offset) 285 { 286 seq_printf(s, "%s", dev_name(pctldev->dev)); 287 } 288 289 static int at91_dt_node_to_map(struct pinctrl_dev *pctldev, 290 struct device_node *np, 291 struct pinctrl_map **map, unsigned *num_maps) 292 { 293 struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); 294 const struct at91_pin_group *grp; 295 struct pinctrl_map *new_map; 296 struct device_node *parent; 297 int map_num = 1; 298 int i; 299 300 /* 301 * first find the group of this node and check if we need to create 302 * config maps for pins 303 */ 304 grp = at91_pinctrl_find_group_by_name(info, np->name); 305 if (!grp) { 306 dev_err(info->dev, "unable to find group for node %pOFn\n", 307 np); 308 return -EINVAL; 309 } 310 311 map_num += grp->npins; 312 new_map = devm_kcalloc(pctldev->dev, map_num, sizeof(*new_map), 313 GFP_KERNEL); 314 if (!new_map) 315 return -ENOMEM; 316 317 *map = new_map; 318 *num_maps = map_num; 319 320 /* create mux map */ 321 parent = of_get_parent(np); 322 if (!parent) { 323 devm_kfree(pctldev->dev, new_map); 324 return -EINVAL; 325 } 326 new_map[0].type = PIN_MAP_TYPE_MUX_GROUP; 327 new_map[0].data.mux.function = parent->name; 328 new_map[0].data.mux.group = np->name; 329 of_node_put(parent); 330 331 /* create config map */ 332 new_map++; 333 for (i = 0; i < grp->npins; i++) { 334 new_map[i].type = PIN_MAP_TYPE_CONFIGS_PIN; 335 new_map[i].data.configs.group_or_pin = 336 pin_get_name(pctldev, grp->pins[i]); 337 new_map[i].data.configs.configs = &grp->pins_conf[i].conf; 338 new_map[i].data.configs.num_configs = 1; 339 } 340 341 dev_dbg(pctldev->dev, "maps: function %s group %s num %d\n", 342 (*map)->data.mux.function, (*map)->data.mux.group, map_num); 343 344 return 0; 345 } 346 347 static void at91_dt_free_map(struct pinctrl_dev *pctldev, 348 struct pinctrl_map *map, unsigned num_maps) 349 { 350 } 351 352 static const struct pinctrl_ops at91_pctrl_ops = { 353 .get_groups_count = at91_get_groups_count, 354 .get_group_name = at91_get_group_name, 355 .get_group_pins = at91_get_group_pins, 356 .pin_dbg_show = at91_pin_dbg_show, 357 .dt_node_to_map = at91_dt_node_to_map, 358 .dt_free_map = at91_dt_free_map, 359 }; 360 361 static void __iomem *pin_to_controller(struct at91_pinctrl *info, 362 unsigned int bank) 363 { 364 if (!gpio_chips[bank]) 365 return NULL; 366 367 return gpio_chips[bank]->regbase; 368 } 369 370 static inline int pin_to_bank(unsigned pin) 371 { 372 return pin /= MAX_NB_GPIO_PER_BANK; 373 } 374 375 static unsigned pin_to_mask(unsigned int pin) 376 { 377 return 1 << pin; 378 } 379 380 static unsigned two_bit_pin_value_shift_amount(unsigned int pin) 381 { 382 /* return the shift value for a pin for "two bit" per pin registers, 383 * i.e. drive strength */ 384 return 2*((pin >= MAX_NB_GPIO_PER_BANK/2) 385 ? pin - MAX_NB_GPIO_PER_BANK/2 : pin); 386 } 387 388 static unsigned sama5d3_get_drive_register(unsigned int pin) 389 { 390 /* drive strength is split between two registers 391 * with two bits per pin */ 392 return (pin >= MAX_NB_GPIO_PER_BANK/2) 393 ? SAMA5D3_PIO_DRIVER2 : SAMA5D3_PIO_DRIVER1; 394 } 395 396 static unsigned at91sam9x5_get_drive_register(unsigned int pin) 397 { 398 /* drive strength is split between two registers 399 * with two bits per pin */ 400 return (pin >= MAX_NB_GPIO_PER_BANK/2) 401 ? AT91SAM9X5_PIO_DRIVER2 : AT91SAM9X5_PIO_DRIVER1; 402 } 403 404 static void at91_mux_disable_interrupt(void __iomem *pio, unsigned mask) 405 { 406 writel_relaxed(mask, pio + PIO_IDR); 407 } 408 409 static unsigned at91_mux_get_pullup(void __iomem *pio, unsigned pin) 410 { 411 return !((readl_relaxed(pio + PIO_PUSR) >> pin) & 0x1); 412 } 413 414 static void at91_mux_set_pullup(void __iomem *pio, unsigned mask, bool on) 415 { 416 if (on) 417 writel_relaxed(mask, pio + PIO_PPDDR); 418 419 writel_relaxed(mask, pio + (on ? PIO_PUER : PIO_PUDR)); 420 } 421 422 static bool at91_mux_get_output(void __iomem *pio, unsigned int pin, bool *val) 423 { 424 *val = (readl_relaxed(pio + PIO_ODSR) >> pin) & 0x1; 425 return (readl_relaxed(pio + PIO_OSR) >> pin) & 0x1; 426 } 427 428 static void at91_mux_set_output(void __iomem *pio, unsigned int mask, 429 bool is_on, bool val) 430 { 431 writel_relaxed(mask, pio + (val ? PIO_SODR : PIO_CODR)); 432 writel_relaxed(mask, pio + (is_on ? PIO_OER : PIO_ODR)); 433 } 434 435 static unsigned at91_mux_get_multidrive(void __iomem *pio, unsigned pin) 436 { 437 return (readl_relaxed(pio + PIO_MDSR) >> pin) & 0x1; 438 } 439 440 static void at91_mux_set_multidrive(void __iomem *pio, unsigned mask, bool on) 441 { 442 writel_relaxed(mask, pio + (on ? PIO_MDER : PIO_MDDR)); 443 } 444 445 static void at91_mux_set_A_periph(void __iomem *pio, unsigned mask) 446 { 447 writel_relaxed(mask, pio + PIO_ASR); 448 } 449 450 static void at91_mux_set_B_periph(void __iomem *pio, unsigned mask) 451 { 452 writel_relaxed(mask, pio + PIO_BSR); 453 } 454 455 static void at91_mux_pio3_set_A_periph(void __iomem *pio, unsigned mask) 456 { 457 458 writel_relaxed(readl_relaxed(pio + PIO_ABCDSR1) & ~mask, 459 pio + PIO_ABCDSR1); 460 writel_relaxed(readl_relaxed(pio + PIO_ABCDSR2) & ~mask, 461 pio + PIO_ABCDSR2); 462 } 463 464 static void at91_mux_pio3_set_B_periph(void __iomem *pio, unsigned mask) 465 { 466 writel_relaxed(readl_relaxed(pio + PIO_ABCDSR1) | mask, 467 pio + PIO_ABCDSR1); 468 writel_relaxed(readl_relaxed(pio + PIO_ABCDSR2) & ~mask, 469 pio + PIO_ABCDSR2); 470 } 471 472 static void at91_mux_pio3_set_C_periph(void __iomem *pio, unsigned mask) 473 { 474 writel_relaxed(readl_relaxed(pio + PIO_ABCDSR1) & ~mask, pio + PIO_ABCDSR1); 475 writel_relaxed(readl_relaxed(pio + PIO_ABCDSR2) | mask, pio + PIO_ABCDSR2); 476 } 477 478 static void at91_mux_pio3_set_D_periph(void __iomem *pio, unsigned mask) 479 { 480 writel_relaxed(readl_relaxed(pio + PIO_ABCDSR1) | mask, pio + PIO_ABCDSR1); 481 writel_relaxed(readl_relaxed(pio + PIO_ABCDSR2) | mask, pio + PIO_ABCDSR2); 482 } 483 484 static enum at91_mux at91_mux_pio3_get_periph(void __iomem *pio, unsigned mask) 485 { 486 unsigned select; 487 488 if (readl_relaxed(pio + PIO_PSR) & mask) 489 return AT91_MUX_GPIO; 490 491 select = !!(readl_relaxed(pio + PIO_ABCDSR1) & mask); 492 select |= (!!(readl_relaxed(pio + PIO_ABCDSR2) & mask) << 1); 493 494 return select + 1; 495 } 496 497 static enum at91_mux at91_mux_get_periph(void __iomem *pio, unsigned mask) 498 { 499 unsigned select; 500 501 if (readl_relaxed(pio + PIO_PSR) & mask) 502 return AT91_MUX_GPIO; 503 504 select = readl_relaxed(pio + PIO_ABSR) & mask; 505 506 return select + 1; 507 } 508 509 static bool at91_mux_get_deglitch(void __iomem *pio, unsigned pin) 510 { 511 return (readl_relaxed(pio + PIO_IFSR) >> pin) & 0x1; 512 } 513 514 static void at91_mux_set_deglitch(void __iomem *pio, unsigned mask, bool is_on) 515 { 516 writel_relaxed(mask, pio + (is_on ? PIO_IFER : PIO_IFDR)); 517 } 518 519 static bool at91_mux_pio3_get_deglitch(void __iomem *pio, unsigned pin) 520 { 521 if ((readl_relaxed(pio + PIO_IFSR) >> pin) & 0x1) 522 return !((readl_relaxed(pio + PIO_IFSCSR) >> pin) & 0x1); 523 524 return false; 525 } 526 527 static void at91_mux_pio3_set_deglitch(void __iomem *pio, unsigned mask, bool is_on) 528 { 529 if (is_on) 530 writel_relaxed(mask, pio + PIO_IFSCDR); 531 at91_mux_set_deglitch(pio, mask, is_on); 532 } 533 534 static bool at91_mux_pio3_get_debounce(void __iomem *pio, unsigned pin, u32 *div) 535 { 536 *div = readl_relaxed(pio + PIO_SCDR); 537 538 return ((readl_relaxed(pio + PIO_IFSR) >> pin) & 0x1) && 539 ((readl_relaxed(pio + PIO_IFSCSR) >> pin) & 0x1); 540 } 541 542 static void at91_mux_pio3_set_debounce(void __iomem *pio, unsigned mask, 543 bool is_on, u32 div) 544 { 545 if (is_on) { 546 writel_relaxed(mask, pio + PIO_IFSCER); 547 writel_relaxed(div & PIO_SCDR_DIV, pio + PIO_SCDR); 548 writel_relaxed(mask, pio + PIO_IFER); 549 } else 550 writel_relaxed(mask, pio + PIO_IFSCDR); 551 } 552 553 static bool at91_mux_pio3_get_pulldown(void __iomem *pio, unsigned pin) 554 { 555 return !((readl_relaxed(pio + PIO_PPDSR) >> pin) & 0x1); 556 } 557 558 static void at91_mux_pio3_set_pulldown(void __iomem *pio, unsigned mask, bool is_on) 559 { 560 if (is_on) 561 writel_relaxed(mask, pio + PIO_PUDR); 562 563 writel_relaxed(mask, pio + (is_on ? PIO_PPDER : PIO_PPDDR)); 564 } 565 566 static void at91_mux_pio3_disable_schmitt_trig(void __iomem *pio, unsigned mask) 567 { 568 writel_relaxed(readl_relaxed(pio + PIO_SCHMITT) | mask, pio + PIO_SCHMITT); 569 } 570 571 static bool at91_mux_pio3_get_schmitt_trig(void __iomem *pio, unsigned pin) 572 { 573 return (readl_relaxed(pio + PIO_SCHMITT) >> pin) & 0x1; 574 } 575 576 static inline u32 read_drive_strength(void __iomem *reg, unsigned pin) 577 { 578 unsigned tmp = readl_relaxed(reg); 579 580 tmp = tmp >> two_bit_pin_value_shift_amount(pin); 581 582 return tmp & DRIVE_STRENGTH_MASK; 583 } 584 585 static unsigned at91_mux_sama5d3_get_drivestrength(void __iomem *pio, 586 unsigned pin) 587 { 588 unsigned tmp = read_drive_strength(pio + 589 sama5d3_get_drive_register(pin), pin); 590 591 /* SAMA5 strength is 1:1 with our defines, 592 * except 0 is equivalent to low per datasheet */ 593 if (!tmp) 594 tmp = DRIVE_STRENGTH_BIT_MSK(LOW); 595 596 return tmp; 597 } 598 599 static unsigned at91_mux_sam9x5_get_drivestrength(void __iomem *pio, 600 unsigned pin) 601 { 602 unsigned tmp = read_drive_strength(pio + 603 at91sam9x5_get_drive_register(pin), pin); 604 605 /* strength is inverse in SAM9x5s hardware with the pinctrl defines 606 * hardware: 0 = hi, 1 = med, 2 = low, 3 = rsvd */ 607 tmp = DRIVE_STRENGTH_BIT_MSK(HI) - tmp; 608 609 return tmp; 610 } 611 612 static unsigned at91_mux_sam9x60_get_drivestrength(void __iomem *pio, 613 unsigned pin) 614 { 615 unsigned tmp = readl_relaxed(pio + SAM9X60_PIO_DRIVER1); 616 617 if (tmp & BIT(pin)) 618 return DRIVE_STRENGTH_BIT_HI; 619 620 return DRIVE_STRENGTH_BIT_LOW; 621 } 622 623 static unsigned at91_mux_sam9x60_get_slewrate(void __iomem *pio, unsigned pin) 624 { 625 unsigned tmp = readl_relaxed(pio + SAM9X60_PIO_SLEWR); 626 627 if ((tmp & BIT(pin))) 628 return SLEWRATE_BIT_ENA; 629 630 return SLEWRATE_BIT_DIS; 631 } 632 633 static void set_drive_strength(void __iomem *reg, unsigned pin, u32 strength) 634 { 635 unsigned tmp = readl_relaxed(reg); 636 unsigned shift = two_bit_pin_value_shift_amount(pin); 637 638 tmp &= ~(DRIVE_STRENGTH_MASK << shift); 639 tmp |= strength << shift; 640 641 writel_relaxed(tmp, reg); 642 } 643 644 static void at91_mux_sama5d3_set_drivestrength(void __iomem *pio, unsigned pin, 645 u32 setting) 646 { 647 /* do nothing if setting is zero */ 648 if (!setting) 649 return; 650 651 /* strength is 1 to 1 with setting for SAMA5 */ 652 set_drive_strength(pio + sama5d3_get_drive_register(pin), pin, setting); 653 } 654 655 static void at91_mux_sam9x5_set_drivestrength(void __iomem *pio, unsigned pin, 656 u32 setting) 657 { 658 /* do nothing if setting is zero */ 659 if (!setting) 660 return; 661 662 /* strength is inverse on SAM9x5s with our defines 663 * 0 = hi, 1 = med, 2 = low, 3 = rsvd */ 664 setting = DRIVE_STRENGTH_BIT_MSK(HI) - setting; 665 666 set_drive_strength(pio + at91sam9x5_get_drive_register(pin), pin, 667 setting); 668 } 669 670 static void at91_mux_sam9x60_set_drivestrength(void __iomem *pio, unsigned pin, 671 u32 setting) 672 { 673 unsigned int tmp; 674 675 if (setting <= DRIVE_STRENGTH_BIT_DEF || 676 setting == DRIVE_STRENGTH_BIT_MED || 677 setting > DRIVE_STRENGTH_BIT_HI) 678 return; 679 680 tmp = readl_relaxed(pio + SAM9X60_PIO_DRIVER1); 681 682 /* Strength is 0: low, 1: hi */ 683 if (setting == DRIVE_STRENGTH_BIT_LOW) 684 tmp &= ~BIT(pin); 685 else 686 tmp |= BIT(pin); 687 688 writel_relaxed(tmp, pio + SAM9X60_PIO_DRIVER1); 689 } 690 691 static void at91_mux_sam9x60_set_slewrate(void __iomem *pio, unsigned pin, 692 u32 setting) 693 { 694 unsigned int tmp; 695 696 if (setting < SLEWRATE_BIT_ENA || setting > SLEWRATE_BIT_DIS) 697 return; 698 699 tmp = readl_relaxed(pio + SAM9X60_PIO_SLEWR); 700 701 if (setting == SLEWRATE_BIT_DIS) 702 tmp &= ~BIT(pin); 703 else 704 tmp |= BIT(pin); 705 706 writel_relaxed(tmp, pio + SAM9X60_PIO_SLEWR); 707 } 708 709 static const struct at91_pinctrl_mux_ops at91rm9200_ops = { 710 .get_periph = at91_mux_get_periph, 711 .mux_A_periph = at91_mux_set_A_periph, 712 .mux_B_periph = at91_mux_set_B_periph, 713 .get_deglitch = at91_mux_get_deglitch, 714 .set_deglitch = at91_mux_set_deglitch, 715 .irq_type = gpio_irq_type, 716 }; 717 718 static const struct at91_pinctrl_mux_ops at91sam9x5_ops = { 719 .get_periph = at91_mux_pio3_get_periph, 720 .mux_A_periph = at91_mux_pio3_set_A_periph, 721 .mux_B_periph = at91_mux_pio3_set_B_periph, 722 .mux_C_periph = at91_mux_pio3_set_C_periph, 723 .mux_D_periph = at91_mux_pio3_set_D_periph, 724 .get_deglitch = at91_mux_pio3_get_deglitch, 725 .set_deglitch = at91_mux_pio3_set_deglitch, 726 .get_debounce = at91_mux_pio3_get_debounce, 727 .set_debounce = at91_mux_pio3_set_debounce, 728 .get_pulldown = at91_mux_pio3_get_pulldown, 729 .set_pulldown = at91_mux_pio3_set_pulldown, 730 .get_schmitt_trig = at91_mux_pio3_get_schmitt_trig, 731 .disable_schmitt_trig = at91_mux_pio3_disable_schmitt_trig, 732 .get_drivestrength = at91_mux_sam9x5_get_drivestrength, 733 .set_drivestrength = at91_mux_sam9x5_set_drivestrength, 734 .irq_type = alt_gpio_irq_type, 735 }; 736 737 static const struct at91_pinctrl_mux_ops sam9x60_ops = { 738 .get_periph = at91_mux_pio3_get_periph, 739 .mux_A_periph = at91_mux_pio3_set_A_periph, 740 .mux_B_periph = at91_mux_pio3_set_B_periph, 741 .mux_C_periph = at91_mux_pio3_set_C_periph, 742 .mux_D_periph = at91_mux_pio3_set_D_periph, 743 .get_deglitch = at91_mux_pio3_get_deglitch, 744 .set_deglitch = at91_mux_pio3_set_deglitch, 745 .get_debounce = at91_mux_pio3_get_debounce, 746 .set_debounce = at91_mux_pio3_set_debounce, 747 .get_pulldown = at91_mux_pio3_get_pulldown, 748 .set_pulldown = at91_mux_pio3_set_pulldown, 749 .get_schmitt_trig = at91_mux_pio3_get_schmitt_trig, 750 .disable_schmitt_trig = at91_mux_pio3_disable_schmitt_trig, 751 .get_drivestrength = at91_mux_sam9x60_get_drivestrength, 752 .set_drivestrength = at91_mux_sam9x60_set_drivestrength, 753 .get_slewrate = at91_mux_sam9x60_get_slewrate, 754 .set_slewrate = at91_mux_sam9x60_set_slewrate, 755 .irq_type = alt_gpio_irq_type, 756 }; 757 758 static const struct at91_pinctrl_mux_ops sama5d3_ops = { 759 .get_periph = at91_mux_pio3_get_periph, 760 .mux_A_periph = at91_mux_pio3_set_A_periph, 761 .mux_B_periph = at91_mux_pio3_set_B_periph, 762 .mux_C_periph = at91_mux_pio3_set_C_periph, 763 .mux_D_periph = at91_mux_pio3_set_D_periph, 764 .get_deglitch = at91_mux_pio3_get_deglitch, 765 .set_deglitch = at91_mux_pio3_set_deglitch, 766 .get_debounce = at91_mux_pio3_get_debounce, 767 .set_debounce = at91_mux_pio3_set_debounce, 768 .get_pulldown = at91_mux_pio3_get_pulldown, 769 .set_pulldown = at91_mux_pio3_set_pulldown, 770 .get_schmitt_trig = at91_mux_pio3_get_schmitt_trig, 771 .disable_schmitt_trig = at91_mux_pio3_disable_schmitt_trig, 772 .get_drivestrength = at91_mux_sama5d3_get_drivestrength, 773 .set_drivestrength = at91_mux_sama5d3_set_drivestrength, 774 .irq_type = alt_gpio_irq_type, 775 }; 776 777 static void at91_pin_dbg(const struct device *dev, const struct at91_pmx_pin *pin) 778 { 779 if (pin->mux) { 780 dev_dbg(dev, "pio%c%d configured as periph%c with conf = 0x%lx\n", 781 pin->bank + 'A', pin->pin, pin->mux - 1 + 'A', pin->conf); 782 } else { 783 dev_dbg(dev, "pio%c%d configured as gpio with conf = 0x%lx\n", 784 pin->bank + 'A', pin->pin, pin->conf); 785 } 786 } 787 788 static int pin_check_config(struct at91_pinctrl *info, const char *name, 789 int index, const struct at91_pmx_pin *pin) 790 { 791 int mux; 792 793 /* check if it's a valid config */ 794 if (pin->bank >= gpio_banks) { 795 dev_err(info->dev, "%s: pin conf %d bank_id %d >= nbanks %d\n", 796 name, index, pin->bank, gpio_banks); 797 return -EINVAL; 798 } 799 800 if (!gpio_chips[pin->bank]) { 801 dev_err(info->dev, "%s: pin conf %d bank_id %d not enabled\n", 802 name, index, pin->bank); 803 return -ENXIO; 804 } 805 806 if (pin->pin >= MAX_NB_GPIO_PER_BANK) { 807 dev_err(info->dev, "%s: pin conf %d pin_bank_id %d >= %d\n", 808 name, index, pin->pin, MAX_NB_GPIO_PER_BANK); 809 return -EINVAL; 810 } 811 812 if (!pin->mux) 813 return 0; 814 815 mux = pin->mux - 1; 816 817 if (mux >= info->nmux) { 818 dev_err(info->dev, "%s: pin conf %d mux_id %d >= nmux %d\n", 819 name, index, mux, info->nmux); 820 return -EINVAL; 821 } 822 823 if (!(info->mux_mask[pin->bank * info->nmux + mux] & 1 << pin->pin)) { 824 dev_err(info->dev, "%s: pin conf %d mux_id %d not supported for pio%c%d\n", 825 name, index, mux, pin->bank + 'A', pin->pin); 826 return -EINVAL; 827 } 828 829 return 0; 830 } 831 832 static void at91_mux_gpio_disable(void __iomem *pio, unsigned mask) 833 { 834 writel_relaxed(mask, pio + PIO_PDR); 835 } 836 837 static void at91_mux_gpio_enable(void __iomem *pio, unsigned mask, bool input) 838 { 839 writel_relaxed(mask, pio + PIO_PER); 840 writel_relaxed(mask, pio + (input ? PIO_ODR : PIO_OER)); 841 } 842 843 static int at91_pmx_set(struct pinctrl_dev *pctldev, unsigned selector, 844 unsigned group) 845 { 846 struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); 847 const struct at91_pmx_pin *pins_conf = info->groups[group].pins_conf; 848 const struct at91_pmx_pin *pin; 849 uint32_t npins = info->groups[group].npins; 850 int i, ret; 851 unsigned mask; 852 void __iomem *pio; 853 854 dev_dbg(info->dev, "enable function %s group %s\n", 855 info->functions[selector].name, info->groups[group].name); 856 857 /* first check that all the pins of the group are valid with a valid 858 * parameter */ 859 for (i = 0; i < npins; i++) { 860 pin = &pins_conf[i]; 861 ret = pin_check_config(info, info->groups[group].name, i, pin); 862 if (ret) 863 return ret; 864 } 865 866 for (i = 0; i < npins; i++) { 867 pin = &pins_conf[i]; 868 at91_pin_dbg(info->dev, pin); 869 pio = pin_to_controller(info, pin->bank); 870 871 if (!pio) 872 continue; 873 874 mask = pin_to_mask(pin->pin); 875 at91_mux_disable_interrupt(pio, mask); 876 switch (pin->mux) { 877 case AT91_MUX_GPIO: 878 at91_mux_gpio_enable(pio, mask, 1); 879 break; 880 case AT91_MUX_PERIPH_A: 881 info->ops->mux_A_periph(pio, mask); 882 break; 883 case AT91_MUX_PERIPH_B: 884 info->ops->mux_B_periph(pio, mask); 885 break; 886 case AT91_MUX_PERIPH_C: 887 if (!info->ops->mux_C_periph) 888 return -EINVAL; 889 info->ops->mux_C_periph(pio, mask); 890 break; 891 case AT91_MUX_PERIPH_D: 892 if (!info->ops->mux_D_periph) 893 return -EINVAL; 894 info->ops->mux_D_periph(pio, mask); 895 break; 896 } 897 if (pin->mux) 898 at91_mux_gpio_disable(pio, mask); 899 } 900 901 return 0; 902 } 903 904 static int at91_pmx_get_funcs_count(struct pinctrl_dev *pctldev) 905 { 906 struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); 907 908 return info->nfunctions; 909 } 910 911 static const char *at91_pmx_get_func_name(struct pinctrl_dev *pctldev, 912 unsigned selector) 913 { 914 struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); 915 916 return info->functions[selector].name; 917 } 918 919 static int at91_pmx_get_groups(struct pinctrl_dev *pctldev, unsigned selector, 920 const char * const **groups, 921 unsigned * const num_groups) 922 { 923 struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); 924 925 *groups = info->functions[selector].groups; 926 *num_groups = info->functions[selector].ngroups; 927 928 return 0; 929 } 930 931 static int at91_gpio_request_enable(struct pinctrl_dev *pctldev, 932 struct pinctrl_gpio_range *range, 933 unsigned offset) 934 { 935 struct at91_pinctrl *npct = pinctrl_dev_get_drvdata(pctldev); 936 struct at91_gpio_chip *at91_chip; 937 struct gpio_chip *chip; 938 unsigned mask; 939 940 if (!range) { 941 dev_err(npct->dev, "invalid range\n"); 942 return -EINVAL; 943 } 944 if (!range->gc) { 945 dev_err(npct->dev, "missing GPIO chip in range\n"); 946 return -EINVAL; 947 } 948 chip = range->gc; 949 at91_chip = gpiochip_get_data(chip); 950 951 dev_dbg(npct->dev, "enable pin %u as GPIO\n", offset); 952 953 mask = 1 << (offset - chip->base); 954 955 dev_dbg(npct->dev, "enable pin %u as PIO%c%d 0x%x\n", 956 offset, 'A' + range->id, offset - chip->base, mask); 957 958 writel_relaxed(mask, at91_chip->regbase + PIO_PER); 959 960 return 0; 961 } 962 963 static void at91_gpio_disable_free(struct pinctrl_dev *pctldev, 964 struct pinctrl_gpio_range *range, 965 unsigned offset) 966 { 967 struct at91_pinctrl *npct = pinctrl_dev_get_drvdata(pctldev); 968 969 dev_dbg(npct->dev, "disable pin %u as GPIO\n", offset); 970 /* Set the pin to some default state, GPIO is usually default */ 971 } 972 973 static const struct pinmux_ops at91_pmx_ops = { 974 .get_functions_count = at91_pmx_get_funcs_count, 975 .get_function_name = at91_pmx_get_func_name, 976 .get_function_groups = at91_pmx_get_groups, 977 .set_mux = at91_pmx_set, 978 .gpio_request_enable = at91_gpio_request_enable, 979 .gpio_disable_free = at91_gpio_disable_free, 980 }; 981 982 static int at91_pinconf_get(struct pinctrl_dev *pctldev, 983 unsigned pin_id, unsigned long *config) 984 { 985 struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); 986 void __iomem *pio; 987 unsigned pin; 988 int div; 989 bool out; 990 991 *config = 0; 992 dev_dbg(info->dev, "%s:%d, pin_id=%d", __func__, __LINE__, pin_id); 993 pio = pin_to_controller(info, pin_to_bank(pin_id)); 994 995 if (!pio) 996 return -EINVAL; 997 998 pin = pin_id % MAX_NB_GPIO_PER_BANK; 999 1000 if (at91_mux_get_multidrive(pio, pin)) 1001 *config |= MULTI_DRIVE; 1002 1003 if (at91_mux_get_pullup(pio, pin)) 1004 *config |= PULL_UP; 1005 1006 if (info->ops->get_deglitch && info->ops->get_deglitch(pio, pin)) 1007 *config |= DEGLITCH; 1008 if (info->ops->get_debounce && info->ops->get_debounce(pio, pin, &div)) 1009 *config |= DEBOUNCE | (div << DEBOUNCE_VAL_SHIFT); 1010 if (info->ops->get_pulldown && info->ops->get_pulldown(pio, pin)) 1011 *config |= PULL_DOWN; 1012 if (info->ops->get_schmitt_trig && info->ops->get_schmitt_trig(pio, pin)) 1013 *config |= DIS_SCHMIT; 1014 if (info->ops->get_drivestrength) 1015 *config |= (info->ops->get_drivestrength(pio, pin) 1016 << DRIVE_STRENGTH_SHIFT); 1017 if (info->ops->get_slewrate) 1018 *config |= (info->ops->get_slewrate(pio, pin) << SLEWRATE_SHIFT); 1019 if (at91_mux_get_output(pio, pin, &out)) 1020 *config |= OUTPUT | (out << OUTPUT_VAL_SHIFT); 1021 1022 return 0; 1023 } 1024 1025 static int at91_pinconf_set(struct pinctrl_dev *pctldev, 1026 unsigned pin_id, unsigned long *configs, 1027 unsigned num_configs) 1028 { 1029 struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); 1030 unsigned mask; 1031 void __iomem *pio; 1032 int i; 1033 unsigned long config; 1034 unsigned pin; 1035 1036 for (i = 0; i < num_configs; i++) { 1037 config = configs[i]; 1038 1039 dev_dbg(info->dev, 1040 "%s:%d, pin_id=%d, config=0x%lx", 1041 __func__, __LINE__, pin_id, config); 1042 pio = pin_to_controller(info, pin_to_bank(pin_id)); 1043 1044 if (!pio) 1045 return -EINVAL; 1046 1047 pin = pin_id % MAX_NB_GPIO_PER_BANK; 1048 mask = pin_to_mask(pin); 1049 1050 if (config & PULL_UP && config & PULL_DOWN) 1051 return -EINVAL; 1052 1053 at91_mux_set_output(pio, mask, config & OUTPUT, 1054 (config & OUTPUT_VAL) >> OUTPUT_VAL_SHIFT); 1055 at91_mux_set_pullup(pio, mask, config & PULL_UP); 1056 at91_mux_set_multidrive(pio, mask, config & MULTI_DRIVE); 1057 if (info->ops->set_deglitch) 1058 info->ops->set_deglitch(pio, mask, config & DEGLITCH); 1059 if (info->ops->set_debounce) 1060 info->ops->set_debounce(pio, mask, config & DEBOUNCE, 1061 (config & DEBOUNCE_VAL) >> DEBOUNCE_VAL_SHIFT); 1062 if (info->ops->set_pulldown) 1063 info->ops->set_pulldown(pio, mask, config & PULL_DOWN); 1064 if (info->ops->disable_schmitt_trig && config & DIS_SCHMIT) 1065 info->ops->disable_schmitt_trig(pio, mask); 1066 if (info->ops->set_drivestrength) 1067 info->ops->set_drivestrength(pio, pin, 1068 (config & DRIVE_STRENGTH) 1069 >> DRIVE_STRENGTH_SHIFT); 1070 if (info->ops->set_slewrate) 1071 info->ops->set_slewrate(pio, pin, 1072 (config & SLEWRATE) >> SLEWRATE_SHIFT); 1073 1074 } /* for each config */ 1075 1076 return 0; 1077 } 1078 1079 #define DBG_SHOW_FLAG(flag) do { \ 1080 if (config & flag) { \ 1081 if (num_conf) \ 1082 seq_puts(s, "|"); \ 1083 seq_puts(s, #flag); \ 1084 num_conf++; \ 1085 } \ 1086 } while (0) 1087 1088 #define DBG_SHOW_FLAG_MASKED(mask, flag, name) do { \ 1089 if ((config & mask) == flag) { \ 1090 if (num_conf) \ 1091 seq_puts(s, "|"); \ 1092 seq_puts(s, #name); \ 1093 num_conf++; \ 1094 } \ 1095 } while (0) 1096 1097 static void at91_pinconf_dbg_show(struct pinctrl_dev *pctldev, 1098 struct seq_file *s, unsigned pin_id) 1099 { 1100 unsigned long config; 1101 int val, num_conf = 0; 1102 1103 at91_pinconf_get(pctldev, pin_id, &config); 1104 1105 DBG_SHOW_FLAG(MULTI_DRIVE); 1106 DBG_SHOW_FLAG(PULL_UP); 1107 DBG_SHOW_FLAG(PULL_DOWN); 1108 DBG_SHOW_FLAG(DIS_SCHMIT); 1109 DBG_SHOW_FLAG(DEGLITCH); 1110 DBG_SHOW_FLAG_MASKED(DRIVE_STRENGTH, DRIVE_STRENGTH_BIT_MSK(LOW), 1111 DRIVE_STRENGTH_LOW); 1112 DBG_SHOW_FLAG_MASKED(DRIVE_STRENGTH, DRIVE_STRENGTH_BIT_MSK(MED), 1113 DRIVE_STRENGTH_MED); 1114 DBG_SHOW_FLAG_MASKED(DRIVE_STRENGTH, DRIVE_STRENGTH_BIT_MSK(HI), 1115 DRIVE_STRENGTH_HI); 1116 DBG_SHOW_FLAG(SLEWRATE); 1117 DBG_SHOW_FLAG(DEBOUNCE); 1118 if (config & DEBOUNCE) { 1119 val = config >> DEBOUNCE_VAL_SHIFT; 1120 seq_printf(s, "(%d)", val); 1121 } 1122 1123 return; 1124 } 1125 1126 static void at91_pinconf_group_dbg_show(struct pinctrl_dev *pctldev, 1127 struct seq_file *s, unsigned group) 1128 { 1129 } 1130 1131 static const struct pinconf_ops at91_pinconf_ops = { 1132 .pin_config_get = at91_pinconf_get, 1133 .pin_config_set = at91_pinconf_set, 1134 .pin_config_dbg_show = at91_pinconf_dbg_show, 1135 .pin_config_group_dbg_show = at91_pinconf_group_dbg_show, 1136 }; 1137 1138 static struct pinctrl_desc at91_pinctrl_desc = { 1139 .pctlops = &at91_pctrl_ops, 1140 .pmxops = &at91_pmx_ops, 1141 .confops = &at91_pinconf_ops, 1142 .owner = THIS_MODULE, 1143 }; 1144 1145 static const char *gpio_compat = "atmel,at91rm9200-gpio"; 1146 1147 static void at91_pinctrl_child_count(struct at91_pinctrl *info, 1148 struct device_node *np) 1149 { 1150 struct device_node *child; 1151 1152 for_each_child_of_node(np, child) { 1153 if (of_device_is_compatible(child, gpio_compat)) { 1154 if (of_device_is_available(child)) 1155 info->nactive_banks++; 1156 } else { 1157 info->nfunctions++; 1158 info->ngroups += of_get_child_count(child); 1159 } 1160 } 1161 } 1162 1163 static int at91_pinctrl_mux_mask(struct at91_pinctrl *info, 1164 struct device_node *np) 1165 { 1166 int ret = 0; 1167 int size; 1168 const __be32 *list; 1169 1170 list = of_get_property(np, "atmel,mux-mask", &size); 1171 if (!list) { 1172 dev_err(info->dev, "can not read the mux-mask of %d\n", size); 1173 return -EINVAL; 1174 } 1175 1176 size /= sizeof(*list); 1177 if (!size || size % gpio_banks) { 1178 dev_err(info->dev, "wrong mux mask array should be by %d\n", gpio_banks); 1179 return -EINVAL; 1180 } 1181 info->nmux = size / gpio_banks; 1182 1183 info->mux_mask = devm_kcalloc(info->dev, size, sizeof(u32), 1184 GFP_KERNEL); 1185 if (!info->mux_mask) 1186 return -ENOMEM; 1187 1188 ret = of_property_read_u32_array(np, "atmel,mux-mask", 1189 info->mux_mask, size); 1190 if (ret) 1191 dev_err(info->dev, "can not read the mux-mask of %d\n", size); 1192 return ret; 1193 } 1194 1195 static int at91_pinctrl_parse_groups(struct device_node *np, 1196 struct at91_pin_group *grp, 1197 struct at91_pinctrl *info, u32 index) 1198 { 1199 struct at91_pmx_pin *pin; 1200 int size; 1201 const __be32 *list; 1202 int i, j; 1203 1204 dev_dbg(info->dev, "group(%d): %pOFn\n", index, np); 1205 1206 /* Initialise group */ 1207 grp->name = np->name; 1208 1209 /* 1210 * the binding format is atmel,pins = <bank pin mux CONFIG ...>, 1211 * do sanity check and calculate pins number 1212 */ 1213 list = of_get_property(np, "atmel,pins", &size); 1214 /* we do not check return since it's safe node passed down */ 1215 size /= sizeof(*list); 1216 if (!size || size % 4) { 1217 dev_err(info->dev, "wrong pins number or pins and configs should be by 4\n"); 1218 return -EINVAL; 1219 } 1220 1221 grp->npins = size / 4; 1222 pin = grp->pins_conf = devm_kcalloc(info->dev, 1223 grp->npins, 1224 sizeof(struct at91_pmx_pin), 1225 GFP_KERNEL); 1226 grp->pins = devm_kcalloc(info->dev, grp->npins, sizeof(unsigned int), 1227 GFP_KERNEL); 1228 if (!grp->pins_conf || !grp->pins) 1229 return -ENOMEM; 1230 1231 for (i = 0, j = 0; i < size; i += 4, j++) { 1232 pin->bank = be32_to_cpu(*list++); 1233 pin->pin = be32_to_cpu(*list++); 1234 grp->pins[j] = pin->bank * MAX_NB_GPIO_PER_BANK + pin->pin; 1235 pin->mux = be32_to_cpu(*list++); 1236 pin->conf = be32_to_cpu(*list++); 1237 1238 at91_pin_dbg(info->dev, pin); 1239 pin++; 1240 } 1241 1242 return 0; 1243 } 1244 1245 static int at91_pinctrl_parse_functions(struct device_node *np, 1246 struct at91_pinctrl *info, u32 index) 1247 { 1248 struct device_node *child; 1249 struct at91_pmx_func *func; 1250 struct at91_pin_group *grp; 1251 int ret; 1252 static u32 grp_index; 1253 u32 i = 0; 1254 1255 dev_dbg(info->dev, "parse function(%d): %pOFn\n", index, np); 1256 1257 func = &info->functions[index]; 1258 1259 /* Initialise function */ 1260 func->name = np->name; 1261 func->ngroups = of_get_child_count(np); 1262 if (func->ngroups == 0) { 1263 dev_err(info->dev, "no groups defined\n"); 1264 return -EINVAL; 1265 } 1266 func->groups = devm_kcalloc(info->dev, 1267 func->ngroups, sizeof(char *), GFP_KERNEL); 1268 if (!func->groups) 1269 return -ENOMEM; 1270 1271 for_each_child_of_node(np, child) { 1272 func->groups[i] = child->name; 1273 grp = &info->groups[grp_index++]; 1274 ret = at91_pinctrl_parse_groups(child, grp, info, i++); 1275 if (ret) { 1276 of_node_put(child); 1277 return ret; 1278 } 1279 } 1280 1281 return 0; 1282 } 1283 1284 static const struct of_device_id at91_pinctrl_of_match[] = { 1285 { .compatible = "atmel,sama5d3-pinctrl", .data = &sama5d3_ops }, 1286 { .compatible = "atmel,at91sam9x5-pinctrl", .data = &at91sam9x5_ops }, 1287 { .compatible = "atmel,at91rm9200-pinctrl", .data = &at91rm9200_ops }, 1288 { .compatible = "microchip,sam9x60-pinctrl", .data = &sam9x60_ops }, 1289 { /* sentinel */ } 1290 }; 1291 1292 static int at91_pinctrl_probe_dt(struct platform_device *pdev, 1293 struct at91_pinctrl *info) 1294 { 1295 struct device *dev = &pdev->dev; 1296 int ret = 0; 1297 int i, j, ngpio_chips_enabled = 0; 1298 uint32_t *tmp; 1299 struct device_node *np = dev->of_node; 1300 struct device_node *child; 1301 1302 if (!np) 1303 return -ENODEV; 1304 1305 info->dev = dev; 1306 info->ops = of_device_get_match_data(dev); 1307 at91_pinctrl_child_count(info, np); 1308 1309 /* 1310 * We need all the GPIO drivers to probe FIRST, or we will not be able 1311 * to obtain references to the struct gpio_chip * for them, and we 1312 * need this to proceed. 1313 */ 1314 for (i = 0; i < MAX_GPIO_BANKS; i++) 1315 if (gpio_chips[i]) 1316 ngpio_chips_enabled++; 1317 1318 if (ngpio_chips_enabled < info->nactive_banks) 1319 return -EPROBE_DEFER; 1320 1321 ret = at91_pinctrl_mux_mask(info, np); 1322 if (ret) 1323 return ret; 1324 1325 dev_dbg(dev, "nmux = %d\n", info->nmux); 1326 1327 dev_dbg(dev, "mux-mask\n"); 1328 tmp = info->mux_mask; 1329 for (i = 0; i < gpio_banks; i++) { 1330 for (j = 0; j < info->nmux; j++, tmp++) { 1331 dev_dbg(dev, "%d:%d\t0x%x\n", i, j, tmp[0]); 1332 } 1333 } 1334 1335 dev_dbg(dev, "nfunctions = %d\n", info->nfunctions); 1336 dev_dbg(dev, "ngroups = %d\n", info->ngroups); 1337 info->functions = devm_kcalloc(dev, info->nfunctions, sizeof(*info->functions), 1338 GFP_KERNEL); 1339 if (!info->functions) 1340 return -ENOMEM; 1341 1342 info->groups = devm_kcalloc(dev, info->ngroups, sizeof(*info->groups), 1343 GFP_KERNEL); 1344 if (!info->groups) 1345 return -ENOMEM; 1346 1347 dev_dbg(dev, "nbanks = %d\n", gpio_banks); 1348 dev_dbg(dev, "nfunctions = %d\n", info->nfunctions); 1349 dev_dbg(dev, "ngroups = %d\n", info->ngroups); 1350 1351 i = 0; 1352 1353 for_each_child_of_node(np, child) { 1354 if (of_device_is_compatible(child, gpio_compat)) 1355 continue; 1356 ret = at91_pinctrl_parse_functions(child, info, i++); 1357 if (ret) { 1358 of_node_put(child); 1359 return dev_err_probe(dev, ret, "failed to parse function\n"); 1360 } 1361 } 1362 1363 return 0; 1364 } 1365 1366 static int at91_pinctrl_probe(struct platform_device *pdev) 1367 { 1368 struct device *dev = &pdev->dev; 1369 struct at91_pinctrl *info; 1370 struct pinctrl_pin_desc *pdesc; 1371 int ret, i, j, k; 1372 1373 info = devm_kzalloc(dev, sizeof(*info), GFP_KERNEL); 1374 if (!info) 1375 return -ENOMEM; 1376 1377 ret = at91_pinctrl_probe_dt(pdev, info); 1378 if (ret) 1379 return ret; 1380 1381 at91_pinctrl_desc.name = dev_name(dev); 1382 at91_pinctrl_desc.npins = gpio_banks * MAX_NB_GPIO_PER_BANK; 1383 at91_pinctrl_desc.pins = pdesc = 1384 devm_kcalloc(dev, at91_pinctrl_desc.npins, sizeof(*pdesc), GFP_KERNEL); 1385 if (!at91_pinctrl_desc.pins) 1386 return -ENOMEM; 1387 1388 for (i = 0, k = 0; i < gpio_banks; i++) { 1389 char **names; 1390 1391 names = devm_kasprintf_strarray(dev, "pio", MAX_NB_GPIO_PER_BANK); 1392 if (IS_ERR(names)) 1393 return PTR_ERR(names); 1394 1395 for (j = 0; j < MAX_NB_GPIO_PER_BANK; j++, k++) { 1396 char *name = names[j]; 1397 1398 strreplace(name, '-', i + 'A'); 1399 1400 pdesc->number = k; 1401 pdesc->name = name; 1402 pdesc++; 1403 } 1404 } 1405 1406 platform_set_drvdata(pdev, info); 1407 info->pctl = devm_pinctrl_register(dev, &at91_pinctrl_desc, info); 1408 if (IS_ERR(info->pctl)) 1409 return dev_err_probe(dev, PTR_ERR(info->pctl), "could not register AT91 pinctrl driver\n"); 1410 1411 /* We will handle a range of GPIO pins */ 1412 for (i = 0; i < gpio_banks; i++) 1413 if (gpio_chips[i]) { 1414 pinctrl_add_gpio_range(info->pctl, &gpio_chips[i]->range); 1415 gpiochip_add_pin_range(&gpio_chips[i]->chip, dev_name(info->pctl->dev), 0, 1416 gpio_chips[i]->range.pin_base, gpio_chips[i]->range.npins); 1417 } 1418 1419 dev_info(dev, "initialized AT91 pinctrl driver\n"); 1420 1421 return 0; 1422 } 1423 1424 static int at91_gpio_get_direction(struct gpio_chip *chip, unsigned offset) 1425 { 1426 struct at91_gpio_chip *at91_gpio = gpiochip_get_data(chip); 1427 void __iomem *pio = at91_gpio->regbase; 1428 unsigned mask = 1 << offset; 1429 u32 osr; 1430 1431 osr = readl_relaxed(pio + PIO_OSR); 1432 if (osr & mask) 1433 return GPIO_LINE_DIRECTION_OUT; 1434 1435 return GPIO_LINE_DIRECTION_IN; 1436 } 1437 1438 static int at91_gpio_direction_input(struct gpio_chip *chip, unsigned offset) 1439 { 1440 struct at91_gpio_chip *at91_gpio = gpiochip_get_data(chip); 1441 void __iomem *pio = at91_gpio->regbase; 1442 unsigned mask = 1 << offset; 1443 1444 writel_relaxed(mask, pio + PIO_ODR); 1445 return 0; 1446 } 1447 1448 static int at91_gpio_get(struct gpio_chip *chip, unsigned offset) 1449 { 1450 struct at91_gpio_chip *at91_gpio = gpiochip_get_data(chip); 1451 void __iomem *pio = at91_gpio->regbase; 1452 unsigned mask = 1 << offset; 1453 u32 pdsr; 1454 1455 pdsr = readl_relaxed(pio + PIO_PDSR); 1456 return (pdsr & mask) != 0; 1457 } 1458 1459 static void at91_gpio_set(struct gpio_chip *chip, unsigned offset, 1460 int val) 1461 { 1462 struct at91_gpio_chip *at91_gpio = gpiochip_get_data(chip); 1463 void __iomem *pio = at91_gpio->regbase; 1464 unsigned mask = 1 << offset; 1465 1466 writel_relaxed(mask, pio + (val ? PIO_SODR : PIO_CODR)); 1467 } 1468 1469 static void at91_gpio_set_multiple(struct gpio_chip *chip, 1470 unsigned long *mask, unsigned long *bits) 1471 { 1472 struct at91_gpio_chip *at91_gpio = gpiochip_get_data(chip); 1473 void __iomem *pio = at91_gpio->regbase; 1474 1475 #define BITS_MASK(bits) (((bits) == 32) ? ~0U : (BIT(bits) - 1)) 1476 /* Mask additionally to ngpio as not all GPIO controllers have 32 pins */ 1477 uint32_t set_mask = (*mask & *bits) & BITS_MASK(chip->ngpio); 1478 uint32_t clear_mask = (*mask & ~(*bits)) & BITS_MASK(chip->ngpio); 1479 1480 writel_relaxed(set_mask, pio + PIO_SODR); 1481 writel_relaxed(clear_mask, pio + PIO_CODR); 1482 } 1483 1484 static int at91_gpio_direction_output(struct gpio_chip *chip, unsigned offset, 1485 int val) 1486 { 1487 struct at91_gpio_chip *at91_gpio = gpiochip_get_data(chip); 1488 void __iomem *pio = at91_gpio->regbase; 1489 unsigned mask = 1 << offset; 1490 1491 writel_relaxed(mask, pio + (val ? PIO_SODR : PIO_CODR)); 1492 writel_relaxed(mask, pio + PIO_OER); 1493 1494 return 0; 1495 } 1496 1497 #ifdef CONFIG_DEBUG_FS 1498 static void at91_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip) 1499 { 1500 enum at91_mux mode; 1501 int i; 1502 struct at91_gpio_chip *at91_gpio = gpiochip_get_data(chip); 1503 void __iomem *pio = at91_gpio->regbase; 1504 const char *gpio_label; 1505 1506 for_each_requested_gpio(chip, i, gpio_label) { 1507 unsigned mask = pin_to_mask(i); 1508 1509 mode = at91_gpio->ops->get_periph(pio, mask); 1510 seq_printf(s, "[%s] GPIO%s%d: ", 1511 gpio_label, chip->label, i); 1512 if (mode == AT91_MUX_GPIO) { 1513 seq_printf(s, "[gpio] "); 1514 seq_printf(s, "%s ", 1515 readl_relaxed(pio + PIO_OSR) & mask ? 1516 "output" : "input"); 1517 seq_printf(s, "%s\n", 1518 readl_relaxed(pio + PIO_PDSR) & mask ? 1519 "set" : "clear"); 1520 } else { 1521 seq_printf(s, "[periph %c]\n", 1522 mode + 'A' - 1); 1523 } 1524 } 1525 } 1526 #else 1527 #define at91_gpio_dbg_show NULL 1528 #endif 1529 1530 static int gpio_irq_request_resources(struct irq_data *d) 1531 { 1532 struct at91_gpio_chip *at91_gpio = irq_data_get_irq_chip_data(d); 1533 1534 return gpiochip_lock_as_irq(&at91_gpio->chip, irqd_to_hwirq(d)); 1535 } 1536 1537 static void gpio_irq_release_resources(struct irq_data *d) 1538 { 1539 struct at91_gpio_chip *at91_gpio = irq_data_get_irq_chip_data(d); 1540 1541 gpiochip_unlock_as_irq(&at91_gpio->chip, irqd_to_hwirq(d)); 1542 } 1543 1544 /* Several AIC controller irqs are dispatched through this GPIO handler. 1545 * To use any AT91_PIN_* as an externally triggered IRQ, first call 1546 * at91_set_gpio_input() then maybe enable its glitch filter. 1547 * Then just request_irq() with the pin ID; it works like any ARM IRQ 1548 * handler. 1549 * First implementation always triggers on rising and falling edges 1550 * whereas the newer PIO3 can be additionally configured to trigger on 1551 * level, edge with any polarity. 1552 * 1553 * Alternatively, certain pins may be used directly as IRQ0..IRQ6 after 1554 * configuring them with at91_set_a_periph() or at91_set_b_periph(). 1555 * IRQ0..IRQ6 should be configurable, e.g. level vs edge triggering. 1556 */ 1557 1558 static void gpio_irq_mask(struct irq_data *d) 1559 { 1560 struct at91_gpio_chip *at91_gpio = irq_data_get_irq_chip_data(d); 1561 void __iomem *pio = at91_gpio->regbase; 1562 unsigned mask = 1 << d->hwirq; 1563 unsigned gpio = irqd_to_hwirq(d); 1564 1565 gpiochip_disable_irq(&at91_gpio->chip, gpio); 1566 1567 if (pio) 1568 writel_relaxed(mask, pio + PIO_IDR); 1569 } 1570 1571 static void gpio_irq_unmask(struct irq_data *d) 1572 { 1573 struct at91_gpio_chip *at91_gpio = irq_data_get_irq_chip_data(d); 1574 void __iomem *pio = at91_gpio->regbase; 1575 unsigned mask = 1 << d->hwirq; 1576 unsigned gpio = irqd_to_hwirq(d); 1577 1578 gpiochip_enable_irq(&at91_gpio->chip, gpio); 1579 1580 if (pio) 1581 writel_relaxed(mask, pio + PIO_IER); 1582 } 1583 1584 static int gpio_irq_type(struct irq_data *d, unsigned type) 1585 { 1586 switch (type) { 1587 case IRQ_TYPE_NONE: 1588 case IRQ_TYPE_EDGE_BOTH: 1589 return 0; 1590 default: 1591 return -EINVAL; 1592 } 1593 } 1594 1595 /* Alternate irq type for PIO3 support */ 1596 static int alt_gpio_irq_type(struct irq_data *d, unsigned type) 1597 { 1598 struct at91_gpio_chip *at91_gpio = irq_data_get_irq_chip_data(d); 1599 void __iomem *pio = at91_gpio->regbase; 1600 unsigned mask = 1 << d->hwirq; 1601 1602 switch (type) { 1603 case IRQ_TYPE_EDGE_RISING: 1604 irq_set_handler_locked(d, handle_simple_irq); 1605 writel_relaxed(mask, pio + PIO_ESR); 1606 writel_relaxed(mask, pio + PIO_REHLSR); 1607 break; 1608 case IRQ_TYPE_EDGE_FALLING: 1609 irq_set_handler_locked(d, handle_simple_irq); 1610 writel_relaxed(mask, pio + PIO_ESR); 1611 writel_relaxed(mask, pio + PIO_FELLSR); 1612 break; 1613 case IRQ_TYPE_LEVEL_LOW: 1614 irq_set_handler_locked(d, handle_level_irq); 1615 writel_relaxed(mask, pio + PIO_LSR); 1616 writel_relaxed(mask, pio + PIO_FELLSR); 1617 break; 1618 case IRQ_TYPE_LEVEL_HIGH: 1619 irq_set_handler_locked(d, handle_level_irq); 1620 writel_relaxed(mask, pio + PIO_LSR); 1621 writel_relaxed(mask, pio + PIO_REHLSR); 1622 break; 1623 case IRQ_TYPE_EDGE_BOTH: 1624 /* 1625 * disable additional interrupt modes: 1626 * fall back to default behavior 1627 */ 1628 irq_set_handler_locked(d, handle_simple_irq); 1629 writel_relaxed(mask, pio + PIO_AIMDR); 1630 return 0; 1631 case IRQ_TYPE_NONE: 1632 default: 1633 pr_warn("AT91: No type for GPIO irq offset %d\n", d->irq); 1634 return -EINVAL; 1635 } 1636 1637 /* enable additional interrupt modes */ 1638 writel_relaxed(mask, pio + PIO_AIMER); 1639 1640 return 0; 1641 } 1642 1643 static void gpio_irq_ack(struct irq_data *d) 1644 { 1645 /* the interrupt is already cleared before by reading ISR */ 1646 } 1647 1648 static int gpio_irq_set_wake(struct irq_data *d, unsigned state) 1649 { 1650 struct at91_gpio_chip *at91_gpio = irq_data_get_irq_chip_data(d); 1651 unsigned mask = 1 << d->hwirq; 1652 1653 if (state) 1654 at91_gpio->wakeups |= mask; 1655 else 1656 at91_gpio->wakeups &= ~mask; 1657 1658 irq_set_irq_wake(at91_gpio->pioc_virq, state); 1659 1660 return 0; 1661 } 1662 1663 static int at91_gpio_suspend(struct device *dev) 1664 { 1665 struct at91_gpio_chip *at91_chip = dev_get_drvdata(dev); 1666 void __iomem *pio = at91_chip->regbase; 1667 1668 at91_chip->backups = readl_relaxed(pio + PIO_IMR); 1669 writel_relaxed(at91_chip->backups, pio + PIO_IDR); 1670 writel_relaxed(at91_chip->wakeups, pio + PIO_IER); 1671 1672 if (!at91_chip->wakeups) 1673 clk_disable_unprepare(at91_chip->clock); 1674 else 1675 dev_dbg(dev, "GPIO-%c may wake for %08x\n", 1676 'A' + at91_chip->id, at91_chip->wakeups); 1677 1678 return 0; 1679 } 1680 1681 static int at91_gpio_resume(struct device *dev) 1682 { 1683 struct at91_gpio_chip *at91_chip = dev_get_drvdata(dev); 1684 void __iomem *pio = at91_chip->regbase; 1685 1686 if (!at91_chip->wakeups) 1687 clk_prepare_enable(at91_chip->clock); 1688 1689 writel_relaxed(at91_chip->wakeups, pio + PIO_IDR); 1690 writel_relaxed(at91_chip->backups, pio + PIO_IER); 1691 1692 return 0; 1693 } 1694 1695 static void gpio_irq_handler(struct irq_desc *desc) 1696 { 1697 struct irq_chip *chip = irq_desc_get_chip(desc); 1698 struct gpio_chip *gpio_chip = irq_desc_get_handler_data(desc); 1699 struct at91_gpio_chip *at91_gpio = gpiochip_get_data(gpio_chip); 1700 void __iomem *pio = at91_gpio->regbase; 1701 unsigned long isr; 1702 int n; 1703 1704 chained_irq_enter(chip, desc); 1705 for (;;) { 1706 /* Reading ISR acks pending (edge triggered) GPIO interrupts. 1707 * When there are none pending, we're finished unless we need 1708 * to process multiple banks (like ID_PIOCDE on sam9263). 1709 */ 1710 isr = readl_relaxed(pio + PIO_ISR) & readl_relaxed(pio + PIO_IMR); 1711 if (!isr) { 1712 if (!at91_gpio->next) 1713 break; 1714 at91_gpio = at91_gpio->next; 1715 pio = at91_gpio->regbase; 1716 gpio_chip = &at91_gpio->chip; 1717 continue; 1718 } 1719 1720 for_each_set_bit(n, &isr, BITS_PER_LONG) 1721 generic_handle_domain_irq(gpio_chip->irq.domain, n); 1722 } 1723 chained_irq_exit(chip, desc); 1724 /* now it may re-trigger */ 1725 } 1726 1727 static int at91_gpio_of_irq_setup(struct platform_device *pdev, 1728 struct at91_gpio_chip *at91_gpio) 1729 { 1730 struct device *dev = &pdev->dev; 1731 struct gpio_chip *gpiochip_prev = NULL; 1732 struct at91_gpio_chip *prev = NULL; 1733 struct irq_data *d = irq_get_irq_data(at91_gpio->pioc_virq); 1734 struct irq_chip *gpio_irqchip; 1735 struct gpio_irq_chip *girq; 1736 int i; 1737 1738 gpio_irqchip = devm_kzalloc(dev, sizeof(*gpio_irqchip), GFP_KERNEL); 1739 if (!gpio_irqchip) 1740 return -ENOMEM; 1741 1742 at91_gpio->pioc_hwirq = irqd_to_hwirq(d); 1743 1744 gpio_irqchip->name = "GPIO"; 1745 gpio_irqchip->irq_request_resources = gpio_irq_request_resources; 1746 gpio_irqchip->irq_release_resources = gpio_irq_release_resources; 1747 gpio_irqchip->irq_ack = gpio_irq_ack; 1748 gpio_irqchip->irq_disable = gpio_irq_mask; 1749 gpio_irqchip->irq_mask = gpio_irq_mask; 1750 gpio_irqchip->irq_unmask = gpio_irq_unmask; 1751 gpio_irqchip->irq_set_wake = pm_ptr(gpio_irq_set_wake); 1752 gpio_irqchip->irq_set_type = at91_gpio->ops->irq_type; 1753 gpio_irqchip->flags = IRQCHIP_IMMUTABLE; 1754 1755 /* Disable irqs of this PIO controller */ 1756 writel_relaxed(~0, at91_gpio->regbase + PIO_IDR); 1757 1758 /* 1759 * Let the generic code handle this edge IRQ, the chained 1760 * handler will perform the actual work of handling the parent 1761 * interrupt. 1762 */ 1763 girq = &at91_gpio->chip.irq; 1764 gpio_irq_chip_set_chip(girq, gpio_irqchip); 1765 girq->default_type = IRQ_TYPE_NONE; 1766 girq->handler = handle_edge_irq; 1767 1768 /* 1769 * The top level handler handles one bank of GPIOs, except 1770 * on some SoC it can handle up to three... 1771 * We only set up the handler for the first of the list. 1772 */ 1773 gpiochip_prev = irq_get_handler_data(at91_gpio->pioc_virq); 1774 if (!gpiochip_prev) { 1775 girq->parent_handler = gpio_irq_handler; 1776 girq->num_parents = 1; 1777 girq->parents = devm_kcalloc(dev, girq->num_parents, 1778 sizeof(*girq->parents), 1779 GFP_KERNEL); 1780 if (!girq->parents) 1781 return -ENOMEM; 1782 girq->parents[0] = at91_gpio->pioc_virq; 1783 return 0; 1784 } 1785 1786 prev = gpiochip_get_data(gpiochip_prev); 1787 /* we can only have 2 banks before */ 1788 for (i = 0; i < 2; i++) { 1789 if (prev->next) { 1790 prev = prev->next; 1791 } else { 1792 prev->next = at91_gpio; 1793 return 0; 1794 } 1795 } 1796 1797 return -EINVAL; 1798 } 1799 1800 /* This structure is replicated for each GPIO block allocated at probe time */ 1801 static const struct gpio_chip at91_gpio_template = { 1802 .request = gpiochip_generic_request, 1803 .free = gpiochip_generic_free, 1804 .get_direction = at91_gpio_get_direction, 1805 .direction_input = at91_gpio_direction_input, 1806 .get = at91_gpio_get, 1807 .direction_output = at91_gpio_direction_output, 1808 .set = at91_gpio_set, 1809 .set_multiple = at91_gpio_set_multiple, 1810 .dbg_show = at91_gpio_dbg_show, 1811 .can_sleep = false, 1812 .ngpio = MAX_NB_GPIO_PER_BANK, 1813 }; 1814 1815 static const struct of_device_id at91_gpio_of_match[] = { 1816 { .compatible = "atmel,at91sam9x5-gpio", .data = &at91sam9x5_ops, }, 1817 { .compatible = "atmel,at91rm9200-gpio", .data = &at91rm9200_ops }, 1818 { .compatible = "microchip,sam9x60-gpio", .data = &sam9x60_ops }, 1819 { /* sentinel */ } 1820 }; 1821 1822 static int at91_gpio_probe(struct platform_device *pdev) 1823 { 1824 struct device *dev = &pdev->dev; 1825 struct device_node *np = dev->of_node; 1826 struct at91_gpio_chip *at91_chip = NULL; 1827 struct gpio_chip *chip; 1828 struct pinctrl_gpio_range *range; 1829 int ret = 0; 1830 int irq, i; 1831 int alias_idx = of_alias_get_id(np, "gpio"); 1832 uint32_t ngpio; 1833 char **names; 1834 1835 BUG_ON(alias_idx >= ARRAY_SIZE(gpio_chips)); 1836 if (gpio_chips[alias_idx]) 1837 return dev_err_probe(dev, -EBUSY, "%d slot is occupied.\n", alias_idx); 1838 1839 irq = platform_get_irq(pdev, 0); 1840 if (irq < 0) 1841 return irq; 1842 1843 at91_chip = devm_kzalloc(dev, sizeof(*at91_chip), GFP_KERNEL); 1844 if (!at91_chip) 1845 return -ENOMEM; 1846 1847 at91_chip->regbase = devm_platform_ioremap_resource(pdev, 0); 1848 if (IS_ERR(at91_chip->regbase)) 1849 return PTR_ERR(at91_chip->regbase); 1850 1851 at91_chip->ops = of_device_get_match_data(dev); 1852 at91_chip->pioc_virq = irq; 1853 1854 at91_chip->clock = devm_clk_get_enabled(dev, NULL); 1855 if (IS_ERR(at91_chip->clock)) 1856 return dev_err_probe(dev, PTR_ERR(at91_chip->clock), "failed to get clock, ignoring.\n"); 1857 1858 at91_chip->chip = at91_gpio_template; 1859 at91_chip->id = alias_idx; 1860 1861 chip = &at91_chip->chip; 1862 chip->label = dev_name(dev); 1863 chip->parent = dev; 1864 chip->owner = THIS_MODULE; 1865 chip->base = alias_idx * MAX_NB_GPIO_PER_BANK; 1866 1867 if (!of_property_read_u32(np, "#gpio-lines", &ngpio)) { 1868 if (ngpio >= MAX_NB_GPIO_PER_BANK) 1869 dev_err(dev, "at91_gpio.%d, gpio-nb >= %d failback to %d\n", 1870 alias_idx, MAX_NB_GPIO_PER_BANK, MAX_NB_GPIO_PER_BANK); 1871 else 1872 chip->ngpio = ngpio; 1873 } 1874 1875 names = devm_kasprintf_strarray(dev, "pio", chip->ngpio); 1876 if (IS_ERR(names)) 1877 return PTR_ERR(names); 1878 1879 for (i = 0; i < chip->ngpio; i++) 1880 strreplace(names[i], '-', alias_idx + 'A'); 1881 1882 chip->names = (const char *const *)names; 1883 1884 range = &at91_chip->range; 1885 range->name = chip->label; 1886 range->id = alias_idx; 1887 range->pin_base = range->base = range->id * MAX_NB_GPIO_PER_BANK; 1888 1889 range->npins = chip->ngpio; 1890 range->gc = chip; 1891 1892 ret = at91_gpio_of_irq_setup(pdev, at91_chip); 1893 if (ret) 1894 return ret; 1895 1896 ret = gpiochip_add_data(chip, at91_chip); 1897 if (ret) 1898 return ret; 1899 1900 gpio_chips[alias_idx] = at91_chip; 1901 platform_set_drvdata(pdev, at91_chip); 1902 gpio_banks = max(gpio_banks, alias_idx + 1); 1903 1904 dev_info(dev, "at address %p\n", at91_chip->regbase); 1905 1906 return 0; 1907 } 1908 1909 static DEFINE_NOIRQ_DEV_PM_OPS(at91_gpio_pm_ops, at91_gpio_suspend, at91_gpio_resume); 1910 1911 static struct platform_driver at91_gpio_driver = { 1912 .driver = { 1913 .name = "gpio-at91", 1914 .of_match_table = at91_gpio_of_match, 1915 .pm = pm_sleep_ptr(&at91_gpio_pm_ops), 1916 }, 1917 .probe = at91_gpio_probe, 1918 }; 1919 1920 static struct platform_driver at91_pinctrl_driver = { 1921 .driver = { 1922 .name = "pinctrl-at91", 1923 .of_match_table = at91_pinctrl_of_match, 1924 }, 1925 .probe = at91_pinctrl_probe, 1926 }; 1927 1928 static struct platform_driver * const drivers[] = { 1929 &at91_gpio_driver, 1930 &at91_pinctrl_driver, 1931 }; 1932 1933 static int __init at91_pinctrl_init(void) 1934 { 1935 return platform_register_drivers(drivers, ARRAY_SIZE(drivers)); 1936 } 1937 arch_initcall(at91_pinctrl_init); 1938