1 /*- 2 * SPDX-License-Identifier: BSD-2-Clause 3 * 4 * Copyright (c) 2009 Oleksandr Tymoshenko <gonzo@freebsd.org> 5 * All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * 2. Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in the 14 * documentation and/or other materials provided with the distribution. 15 * 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26 * SUCH DAMAGE. 27 */ 28 29 #include <sys/cdefs.h> 30 #include <sys/param.h> 31 #include <sys/systm.h> 32 #include <sys/bus.h> 33 #include <sys/gpio.h> 34 #ifdef INTRNG 35 #include <sys/intr.h> 36 #endif 37 #include <sys/kernel.h> 38 #include <sys/malloc.h> 39 #include <sys/module.h> 40 #include <sys/sbuf.h> 41 42 #include <dev/gpio/gpiobusvar.h> 43 44 #include "gpiobus_if.h" 45 46 #undef GPIOBUS_DEBUG 47 #ifdef GPIOBUS_DEBUG 48 #define dprintf printf 49 #else 50 #define dprintf(x, arg...) 51 #endif 52 53 static void gpiobus_print_pins(struct gpiobus_ivar *, struct sbuf *); 54 static int gpiobus_parse_pins(struct gpiobus_softc *, device_t, int); 55 static int gpiobus_probe(device_t); 56 static int gpiobus_attach(device_t); 57 static int gpiobus_detach(device_t); 58 static int gpiobus_suspend(device_t); 59 static int gpiobus_resume(device_t); 60 static void gpiobus_probe_nomatch(device_t, device_t); 61 static int gpiobus_print_child(device_t, device_t); 62 static int gpiobus_child_location(device_t, device_t, struct sbuf *); 63 static device_t gpiobus_add_child(device_t, u_int, const char *, int); 64 static void gpiobus_hinted_child(device_t, const char *, int); 65 66 /* 67 * GPIOBUS interface 68 */ 69 static int gpiobus_acquire_bus(device_t, device_t, int); 70 static void gpiobus_release_bus(device_t, device_t); 71 static int gpiobus_pin_setflags(device_t, device_t, uint32_t, uint32_t); 72 static int gpiobus_pin_getflags(device_t, device_t, uint32_t, uint32_t*); 73 static int gpiobus_pin_getcaps(device_t, device_t, uint32_t, uint32_t*); 74 static int gpiobus_pin_set(device_t, device_t, uint32_t, unsigned int); 75 static int gpiobus_pin_get(device_t, device_t, uint32_t, unsigned int*); 76 static int gpiobus_pin_toggle(device_t, device_t, uint32_t); 77 78 /* 79 * gpiobus_pin flags 80 * The flags in struct gpiobus_pin are not related to the flags used by the 81 * low-level controller driver in struct gpio_pin. Currently, only pins 82 * acquired via FDT data have gpiobus_pin.flags set, sourced from the flags in 83 * the FDT properties. In theory, these flags are defined per-platform. In 84 * practice they are always the flags from the dt-bindings/gpio/gpio.h file. 85 * The only one of those flags we currently support is for handling active-low 86 * pins, so we just define that flag here instead of including a GPL'd header. 87 */ 88 #define GPIO_ACTIVE_LOW 1 89 90 /* 91 * XXX -> Move me to better place - gpio_subr.c? 92 * Also, this function must be changed when interrupt configuration 93 * data will be moved into struct resource. 94 */ 95 #ifdef INTRNG 96 97 struct resource * 98 gpio_alloc_intr_resource(device_t consumer_dev, int *rid, u_int alloc_flags, 99 gpio_pin_t pin, uint32_t intr_mode) 100 { 101 u_int irq; 102 struct intr_map_data_gpio *gpio_data; 103 struct resource *res; 104 105 gpio_data = (struct intr_map_data_gpio *)intr_alloc_map_data( 106 INTR_MAP_DATA_GPIO, sizeof(*gpio_data), M_WAITOK | M_ZERO); 107 gpio_data->gpio_pin_num = pin->pin; 108 gpio_data->gpio_pin_flags = pin->flags; 109 gpio_data->gpio_intr_mode = intr_mode; 110 111 irq = intr_map_irq(pin->dev, 0, (struct intr_map_data *)gpio_data); 112 res = bus_alloc_resource(consumer_dev, SYS_RES_IRQ, rid, irq, irq, 1, 113 alloc_flags); 114 if (res == NULL) { 115 intr_free_intr_map_data((struct intr_map_data *)gpio_data); 116 return (NULL); 117 } 118 rman_set_virtual(res, gpio_data); 119 return (res); 120 } 121 #else 122 struct resource * 123 gpio_alloc_intr_resource(device_t consumer_dev, int *rid, u_int alloc_flags, 124 gpio_pin_t pin, uint32_t intr_mode) 125 { 126 127 return (NULL); 128 } 129 #endif 130 131 int 132 gpio_check_flags(uint32_t caps, uint32_t flags) 133 { 134 135 /* Filter unwanted flags. */ 136 flags &= caps; 137 138 /* Cannot mix input/output together. */ 139 if (flags & GPIO_PIN_INPUT && flags & GPIO_PIN_OUTPUT) 140 return (EINVAL); 141 /* Cannot mix pull-up/pull-down together. */ 142 if (flags & GPIO_PIN_PULLUP && flags & GPIO_PIN_PULLDOWN) 143 return (EINVAL); 144 /* Cannot mix output and interrupt flags together */ 145 if (flags & GPIO_PIN_OUTPUT && flags & GPIO_INTR_MASK) 146 return (EINVAL); 147 /* Only one interrupt flag can be defined at once */ 148 if ((flags & GPIO_INTR_MASK) & ((flags & GPIO_INTR_MASK) - 1)) 149 return (EINVAL); 150 /* The interrupt attached flag cannot be set */ 151 if (flags & GPIO_INTR_ATTACHED) 152 return (EINVAL); 153 154 return (0); 155 } 156 157 int 158 gpio_pin_get_by_bus_pinnum(device_t busdev, uint32_t pinnum, gpio_pin_t *ppin) 159 { 160 gpio_pin_t pin; 161 int err; 162 163 err = gpiobus_acquire_pin(busdev, pinnum); 164 if (err != 0) 165 return (EBUSY); 166 167 pin = malloc(sizeof(*pin), M_DEVBUF, M_WAITOK | M_ZERO); 168 169 pin->dev = device_get_parent(busdev); 170 pin->pin = pinnum; 171 pin->flags = 0; 172 173 *ppin = pin; 174 return (0); 175 } 176 177 int 178 gpio_pin_get_by_child_index(device_t childdev, uint32_t idx, gpio_pin_t *ppin) 179 { 180 struct gpiobus_ivar *devi; 181 182 devi = GPIOBUS_IVAR(childdev); 183 if (idx >= devi->npins) 184 return (EINVAL); 185 186 return (gpio_pin_get_by_bus_pinnum(device_get_parent(childdev), 187 devi->pins[idx], ppin)); 188 } 189 190 int 191 gpio_pin_getcaps(gpio_pin_t pin, uint32_t *caps) 192 { 193 194 KASSERT(pin != NULL, ("GPIO pin is NULL.")); 195 KASSERT(pin->dev != NULL, ("GPIO pin device is NULL.")); 196 return (GPIO_PIN_GETCAPS(pin->dev, pin->pin, caps)); 197 } 198 199 int 200 gpio_pin_is_active(gpio_pin_t pin, bool *active) 201 { 202 int rv; 203 uint32_t tmp; 204 205 KASSERT(pin != NULL, ("GPIO pin is NULL.")); 206 KASSERT(pin->dev != NULL, ("GPIO pin device is NULL.")); 207 rv = GPIO_PIN_GET(pin->dev, pin->pin, &tmp); 208 if (rv != 0) { 209 return (rv); 210 } 211 212 if (pin->flags & GPIO_ACTIVE_LOW) 213 *active = tmp == 0; 214 else 215 *active = tmp != 0; 216 return (0); 217 } 218 219 void 220 gpio_pin_release(gpio_pin_t gpio) 221 { 222 device_t busdev; 223 224 if (gpio == NULL) 225 return; 226 227 KASSERT(gpio->dev != NULL, ("GPIO pin device is NULL.")); 228 229 busdev = GPIO_GET_BUS(gpio->dev); 230 if (busdev != NULL) 231 gpiobus_release_pin(busdev, gpio->pin); 232 233 free(gpio, M_DEVBUF); 234 } 235 236 int 237 gpio_pin_set_active(gpio_pin_t pin, bool active) 238 { 239 int rv; 240 uint32_t tmp; 241 242 if (pin->flags & GPIO_ACTIVE_LOW) 243 tmp = active ? 0 : 1; 244 else 245 tmp = active ? 1 : 0; 246 247 KASSERT(pin != NULL, ("GPIO pin is NULL.")); 248 KASSERT(pin->dev != NULL, ("GPIO pin device is NULL.")); 249 rv = GPIO_PIN_SET(pin->dev, pin->pin, tmp); 250 return (rv); 251 } 252 253 int 254 gpio_pin_setflags(gpio_pin_t pin, uint32_t flags) 255 { 256 int rv; 257 258 KASSERT(pin != NULL, ("GPIO pin is NULL.")); 259 KASSERT(pin->dev != NULL, ("GPIO pin device is NULL.")); 260 261 rv = GPIO_PIN_SETFLAGS(pin->dev, pin->pin, flags); 262 return (rv); 263 } 264 265 static void 266 gpiobus_print_pins(struct gpiobus_ivar *devi, struct sbuf *sb) 267 { 268 int i, range_start, range_stop, need_coma; 269 270 if (devi->npins == 0) 271 return; 272 273 need_coma = 0; 274 range_start = range_stop = devi->pins[0]; 275 for (i = 1; i < devi->npins; i++) { 276 if (devi->pins[i] != (range_stop + 1)) { 277 if (need_coma) 278 sbuf_cat(sb, ","); 279 if (range_start != range_stop) 280 sbuf_printf(sb, "%d-%d", range_start, range_stop); 281 else 282 sbuf_printf(sb, "%d", range_start); 283 range_start = range_stop = devi->pins[i]; 284 need_coma = 1; 285 } 286 else 287 range_stop++; 288 } 289 290 if (need_coma) 291 sbuf_cat(sb, ","); 292 if (range_start != range_stop) 293 sbuf_printf(sb, "%d-%d", range_start, range_stop); 294 else 295 sbuf_printf(sb, "%d", range_start); 296 } 297 298 device_t 299 gpiobus_attach_bus(device_t dev) 300 { 301 device_t busdev; 302 303 busdev = device_add_child(dev, "gpiobus", -1); 304 if (busdev == NULL) 305 return (NULL); 306 if (device_add_child(dev, "gpioc", -1) == NULL) { 307 device_delete_child(dev, busdev); 308 return (NULL); 309 } 310 #ifdef FDT 311 ofw_gpiobus_register_provider(dev); 312 #endif 313 bus_generic_attach(dev); 314 315 return (busdev); 316 } 317 318 int 319 gpiobus_detach_bus(device_t dev) 320 { 321 int err; 322 323 #ifdef FDT 324 ofw_gpiobus_unregister_provider(dev); 325 #endif 326 err = bus_generic_detach(dev); 327 if (err != 0) 328 return (err); 329 330 return (device_delete_children(dev)); 331 } 332 333 int 334 gpiobus_init_softc(device_t dev) 335 { 336 struct gpiobus_softc *sc; 337 338 sc = GPIOBUS_SOFTC(dev); 339 sc->sc_busdev = dev; 340 sc->sc_dev = device_get_parent(dev); 341 sc->sc_intr_rman.rm_type = RMAN_ARRAY; 342 sc->sc_intr_rman.rm_descr = "GPIO Interrupts"; 343 if (rman_init(&sc->sc_intr_rman) != 0 || 344 rman_manage_region(&sc->sc_intr_rman, 0, ~0) != 0) 345 panic("%s: failed to set up rman.", __func__); 346 347 if (GPIO_PIN_MAX(sc->sc_dev, &sc->sc_npins) != 0) 348 return (ENXIO); 349 350 KASSERT(sc->sc_npins >= 0, ("GPIO device with no pins")); 351 352 /* Pins = GPIO_PIN_MAX() + 1 */ 353 sc->sc_npins++; 354 355 sc->sc_pins = malloc(sizeof(*sc->sc_pins) * sc->sc_npins, M_DEVBUF, 356 M_NOWAIT | M_ZERO); 357 if (sc->sc_pins == NULL) 358 return (ENOMEM); 359 360 /* Initialize the bus lock. */ 361 GPIOBUS_LOCK_INIT(sc); 362 363 return (0); 364 } 365 366 int 367 gpiobus_alloc_ivars(struct gpiobus_ivar *devi) 368 { 369 370 /* Allocate pins and flags memory. */ 371 devi->pins = malloc(sizeof(uint32_t) * devi->npins, M_DEVBUF, 372 M_NOWAIT | M_ZERO); 373 if (devi->pins == NULL) 374 return (ENOMEM); 375 return (0); 376 } 377 378 void 379 gpiobus_free_ivars(struct gpiobus_ivar *devi) 380 { 381 382 if (devi->pins) { 383 free(devi->pins, M_DEVBUF); 384 devi->pins = NULL; 385 } 386 devi->npins = 0; 387 } 388 389 int 390 gpiobus_acquire_pin(device_t bus, uint32_t pin) 391 { 392 struct gpiobus_softc *sc; 393 394 sc = device_get_softc(bus); 395 /* Consistency check. */ 396 if (pin >= sc->sc_npins) { 397 device_printf(bus, 398 "invalid pin %d, max: %d\n", pin, sc->sc_npins - 1); 399 return (-1); 400 } 401 /* Mark pin as mapped and give warning if it's already mapped. */ 402 if (sc->sc_pins[pin].mapped) { 403 device_printf(bus, "warning: pin %d is already mapped\n", pin); 404 return (-1); 405 } 406 sc->sc_pins[pin].mapped = 1; 407 408 return (0); 409 } 410 411 /* Release mapped pin */ 412 int 413 gpiobus_release_pin(device_t bus, uint32_t pin) 414 { 415 struct gpiobus_softc *sc; 416 417 sc = device_get_softc(bus); 418 /* Consistency check. */ 419 if (pin >= sc->sc_npins) { 420 device_printf(bus, 421 "invalid pin %d, max=%d\n", 422 pin, sc->sc_npins - 1); 423 return (-1); 424 } 425 426 if (!sc->sc_pins[pin].mapped) { 427 device_printf(bus, "pin %d is not mapped\n", pin); 428 return (-1); 429 } 430 sc->sc_pins[pin].mapped = 0; 431 432 return (0); 433 } 434 435 static int 436 gpiobus_acquire_child_pins(device_t dev, device_t child) 437 { 438 struct gpiobus_ivar *devi = GPIOBUS_IVAR(child); 439 int i; 440 441 for (i = 0; i < devi->npins; i++) { 442 /* Reserve the GPIO pin. */ 443 if (gpiobus_acquire_pin(dev, devi->pins[i]) != 0) { 444 device_printf(child, "cannot acquire pin %d\n", 445 devi->pins[i]); 446 while (--i >= 0) { 447 (void)gpiobus_release_pin(dev, 448 devi->pins[i]); 449 } 450 gpiobus_free_ivars(devi); 451 return (EBUSY); 452 } 453 } 454 for (i = 0; i < devi->npins; i++) { 455 /* Use the child name as pin name. */ 456 GPIOBUS_PIN_SETNAME(dev, devi->pins[i], 457 device_get_nameunit(child)); 458 459 } 460 return (0); 461 } 462 463 static int 464 gpiobus_parse_pins(struct gpiobus_softc *sc, device_t child, int mask) 465 { 466 struct gpiobus_ivar *devi = GPIOBUS_IVAR(child); 467 int i, npins; 468 469 npins = 0; 470 for (i = 0; i < 32; i++) { 471 if (mask & (1 << i)) 472 npins++; 473 } 474 if (npins == 0) { 475 device_printf(child, "empty pin mask\n"); 476 return (EINVAL); 477 } 478 devi->npins = npins; 479 if (gpiobus_alloc_ivars(devi) != 0) { 480 device_printf(child, "cannot allocate device ivars\n"); 481 return (EINVAL); 482 } 483 npins = 0; 484 for (i = 0; i < 32; i++) { 485 if ((mask & (1 << i)) == 0) 486 continue; 487 devi->pins[npins++] = i; 488 } 489 490 return (0); 491 } 492 493 static int 494 gpiobus_parse_pin_list(struct gpiobus_softc *sc, device_t child, 495 const char *pins) 496 { 497 struct gpiobus_ivar *devi = GPIOBUS_IVAR(child); 498 const char *p; 499 char *endp; 500 unsigned long pin; 501 int i, npins; 502 503 npins = 0; 504 p = pins; 505 for (;;) { 506 pin = strtoul(p, &endp, 0); 507 if (endp == p) 508 break; 509 npins++; 510 if (*endp == '\0') 511 break; 512 p = endp + 1; 513 } 514 515 if (*endp != '\0') { 516 device_printf(child, "garbage in the pin list: %s\n", endp); 517 return (EINVAL); 518 } 519 if (npins == 0) { 520 device_printf(child, "empty pin list\n"); 521 return (EINVAL); 522 } 523 524 devi->npins = npins; 525 if (gpiobus_alloc_ivars(devi) != 0) { 526 device_printf(child, "cannot allocate device ivars\n"); 527 return (EINVAL); 528 } 529 530 i = 0; 531 p = pins; 532 for (;;) { 533 pin = strtoul(p, &endp, 0); 534 535 devi->pins[i] = pin; 536 537 if (*endp == '\0') 538 break; 539 i++; 540 p = endp + 1; 541 } 542 543 return (0); 544 } 545 546 static int 547 gpiobus_probe(device_t dev) 548 { 549 device_set_desc(dev, "GPIO bus"); 550 551 return (BUS_PROBE_GENERIC); 552 } 553 554 static int 555 gpiobus_attach(device_t dev) 556 { 557 int err; 558 559 err = gpiobus_init_softc(dev); 560 if (err != 0) 561 return (err); 562 563 /* 564 * Get parent's pins and mark them as unmapped 565 */ 566 bus_generic_probe(dev); 567 bus_enumerate_hinted_children(dev); 568 569 return (bus_generic_attach(dev)); 570 } 571 572 /* 573 * Since this is not a self-enumerating bus, and since we always add 574 * children in attach, we have to always delete children here. 575 */ 576 static int 577 gpiobus_detach(device_t dev) 578 { 579 struct gpiobus_softc *sc; 580 struct gpiobus_ivar *devi; 581 device_t *devlist; 582 int i, err, ndevs; 583 584 sc = GPIOBUS_SOFTC(dev); 585 KASSERT(mtx_initialized(&sc->sc_mtx), 586 ("gpiobus mutex not initialized")); 587 GPIOBUS_LOCK_DESTROY(sc); 588 589 if ((err = bus_generic_detach(dev)) != 0) 590 return (err); 591 592 if ((err = device_get_children(dev, &devlist, &ndevs)) != 0) 593 return (err); 594 for (i = 0; i < ndevs; i++) { 595 devi = GPIOBUS_IVAR(devlist[i]); 596 gpiobus_free_ivars(devi); 597 resource_list_free(&devi->rl); 598 free(devi, M_DEVBUF); 599 device_delete_child(dev, devlist[i]); 600 } 601 free(devlist, M_TEMP); 602 rman_fini(&sc->sc_intr_rman); 603 if (sc->sc_pins) { 604 for (i = 0; i < sc->sc_npins; i++) { 605 if (sc->sc_pins[i].name != NULL) 606 free(sc->sc_pins[i].name, M_DEVBUF); 607 sc->sc_pins[i].name = NULL; 608 } 609 free(sc->sc_pins, M_DEVBUF); 610 sc->sc_pins = NULL; 611 } 612 613 return (0); 614 } 615 616 static int 617 gpiobus_suspend(device_t dev) 618 { 619 620 return (bus_generic_suspend(dev)); 621 } 622 623 static int 624 gpiobus_resume(device_t dev) 625 { 626 627 return (bus_generic_resume(dev)); 628 } 629 630 static void 631 gpiobus_probe_nomatch(device_t dev, device_t child) 632 { 633 char pins[128]; 634 struct sbuf sb; 635 struct gpiobus_ivar *devi; 636 637 devi = GPIOBUS_IVAR(child); 638 sbuf_new(&sb, pins, sizeof(pins), SBUF_FIXEDLEN); 639 gpiobus_print_pins(devi, &sb); 640 sbuf_finish(&sb); 641 device_printf(dev, "<unknown device> at pin%s %s", 642 devi->npins > 1 ? "s" : "", sbuf_data(&sb)); 643 resource_list_print_type(&devi->rl, "irq", SYS_RES_IRQ, "%jd"); 644 printf("\n"); 645 } 646 647 static int 648 gpiobus_print_child(device_t dev, device_t child) 649 { 650 char pins[128]; 651 struct sbuf sb; 652 int retval = 0; 653 struct gpiobus_ivar *devi; 654 655 devi = GPIOBUS_IVAR(child); 656 retval += bus_print_child_header(dev, child); 657 if (devi->npins > 0) { 658 if (devi->npins > 1) 659 retval += printf(" at pins "); 660 else 661 retval += printf(" at pin "); 662 sbuf_new(&sb, pins, sizeof(pins), SBUF_FIXEDLEN); 663 gpiobus_print_pins(devi, &sb); 664 sbuf_finish(&sb); 665 retval += printf("%s", sbuf_data(&sb)); 666 } 667 resource_list_print_type(&devi->rl, "irq", SYS_RES_IRQ, "%jd"); 668 retval += bus_print_child_footer(dev, child); 669 670 return (retval); 671 } 672 673 static int 674 gpiobus_child_location(device_t bus, device_t child, struct sbuf *sb) 675 { 676 struct gpiobus_ivar *devi; 677 678 devi = GPIOBUS_IVAR(child); 679 sbuf_printf(sb, "pins="); 680 gpiobus_print_pins(devi, sb); 681 682 return (0); 683 } 684 685 static device_t 686 gpiobus_add_child(device_t dev, u_int order, const char *name, int unit) 687 { 688 device_t child; 689 struct gpiobus_ivar *devi; 690 691 child = device_add_child_ordered(dev, order, name, unit); 692 if (child == NULL) 693 return (child); 694 devi = malloc(sizeof(struct gpiobus_ivar), M_DEVBUF, M_NOWAIT | M_ZERO); 695 if (devi == NULL) { 696 device_delete_child(dev, child); 697 return (NULL); 698 } 699 resource_list_init(&devi->rl); 700 device_set_ivars(child, devi); 701 702 return (child); 703 } 704 705 static int 706 gpiobus_rescan(device_t dev) 707 { 708 709 /* 710 * Re-scan is supposed to remove and add children, but if someone has 711 * deleted the hints for a child we attached earlier, we have no easy 712 * way to handle that. So this just attaches new children for whom new 713 * hints or drivers have arrived since we last tried. 714 */ 715 bus_enumerate_hinted_children(dev); 716 bus_generic_attach(dev); 717 return (0); 718 } 719 720 static void 721 gpiobus_hinted_child(device_t bus, const char *dname, int dunit) 722 { 723 struct gpiobus_softc *sc = GPIOBUS_SOFTC(bus); 724 struct gpiobus_ivar *devi; 725 device_t child; 726 const char *pins; 727 int irq, pinmask; 728 729 if (device_find_child(bus, dname, dunit) != NULL) { 730 return; 731 } 732 733 child = BUS_ADD_CHILD(bus, 0, dname, dunit); 734 devi = GPIOBUS_IVAR(child); 735 if (resource_int_value(dname, dunit, "pins", &pinmask) == 0) { 736 if (gpiobus_parse_pins(sc, child, pinmask)) { 737 resource_list_free(&devi->rl); 738 free(devi, M_DEVBUF); 739 device_delete_child(bus, child); 740 return; 741 } 742 } 743 else if (resource_string_value(dname, dunit, "pin_list", &pins) == 0) { 744 if (gpiobus_parse_pin_list(sc, child, pins)) { 745 resource_list_free(&devi->rl); 746 free(devi, M_DEVBUF); 747 device_delete_child(bus, child); 748 return; 749 } 750 } 751 if (resource_int_value(dname, dunit, "irq", &irq) == 0) { 752 if (bus_set_resource(child, SYS_RES_IRQ, 0, irq, 1) != 0) 753 device_printf(bus, 754 "warning: bus_set_resource() failed\n"); 755 } 756 } 757 758 static int 759 gpiobus_read_ivar(device_t dev, device_t child, int which, uintptr_t *result) 760 { 761 struct gpiobus_ivar *devi; 762 763 devi = GPIOBUS_IVAR(child); 764 switch (which) { 765 case GPIOBUS_IVAR_NPINS: 766 *result = devi->npins; 767 break; 768 case GPIOBUS_IVAR_PINS: 769 /* Children do not ever need to directly examine this. */ 770 return (ENOTSUP); 771 default: 772 return (ENOENT); 773 } 774 775 return (0); 776 } 777 778 static int 779 gpiobus_write_ivar(device_t dev, device_t child, int which, uintptr_t value) 780 { 781 struct gpiobus_ivar *devi; 782 const uint32_t *ptr; 783 int i; 784 785 devi = GPIOBUS_IVAR(child); 786 switch (which) { 787 case GPIOBUS_IVAR_NPINS: 788 /* GPIO ivars are set once. */ 789 if (devi->npins != 0) { 790 return (EBUSY); 791 } 792 devi->npins = value; 793 if (gpiobus_alloc_ivars(devi) != 0) { 794 device_printf(child, "cannot allocate device ivars\n"); 795 devi->npins = 0; 796 return (ENOMEM); 797 } 798 break; 799 case GPIOBUS_IVAR_PINS: 800 ptr = (const uint32_t *)value; 801 for (i = 0; i < devi->npins; i++) 802 devi->pins[i] = ptr[i]; 803 if (gpiobus_acquire_child_pins(dev, child) != 0) 804 return (EBUSY); 805 break; 806 default: 807 return (ENOENT); 808 } 809 810 return (0); 811 } 812 813 static struct resource * 814 gpiobus_alloc_resource(device_t bus, device_t child, int type, int *rid, 815 rman_res_t start, rman_res_t end, rman_res_t count, u_int flags) 816 { 817 struct gpiobus_softc *sc; 818 struct resource *rv; 819 struct resource_list *rl; 820 struct resource_list_entry *rle; 821 int isdefault; 822 823 if (type != SYS_RES_IRQ) 824 return (NULL); 825 isdefault = (RMAN_IS_DEFAULT_RANGE(start, end) && count == 1); 826 rle = NULL; 827 if (isdefault) { 828 rl = BUS_GET_RESOURCE_LIST(bus, child); 829 if (rl == NULL) 830 return (NULL); 831 rle = resource_list_find(rl, type, *rid); 832 if (rle == NULL) 833 return (NULL); 834 if (rle->res != NULL) 835 panic("%s: resource entry is busy", __func__); 836 start = rle->start; 837 count = rle->count; 838 end = rle->end; 839 } 840 sc = device_get_softc(bus); 841 rv = rman_reserve_resource(&sc->sc_intr_rman, start, end, count, flags, 842 child); 843 if (rv == NULL) 844 return (NULL); 845 rman_set_rid(rv, *rid); 846 if ((flags & RF_ACTIVE) != 0 && 847 bus_activate_resource(child, type, *rid, rv) != 0) { 848 rman_release_resource(rv); 849 return (NULL); 850 } 851 852 return (rv); 853 } 854 855 static int 856 gpiobus_release_resource(device_t bus __unused, device_t child, int type, 857 int rid, struct resource *r) 858 { 859 int error; 860 861 if (rman_get_flags(r) & RF_ACTIVE) { 862 error = bus_deactivate_resource(child, type, rid, r); 863 if (error) 864 return (error); 865 } 866 867 return (rman_release_resource(r)); 868 } 869 870 static struct resource_list * 871 gpiobus_get_resource_list(device_t bus __unused, device_t child) 872 { 873 struct gpiobus_ivar *ivar; 874 875 ivar = GPIOBUS_IVAR(child); 876 877 return (&ivar->rl); 878 } 879 880 static int 881 gpiobus_acquire_bus(device_t busdev, device_t child, int how) 882 { 883 struct gpiobus_softc *sc; 884 885 sc = device_get_softc(busdev); 886 GPIOBUS_ASSERT_UNLOCKED(sc); 887 GPIOBUS_LOCK(sc); 888 if (sc->sc_owner != NULL) { 889 if (sc->sc_owner == child) 890 panic("%s: %s still owns the bus.", 891 device_get_nameunit(busdev), 892 device_get_nameunit(child)); 893 if (how == GPIOBUS_DONTWAIT) { 894 GPIOBUS_UNLOCK(sc); 895 return (EWOULDBLOCK); 896 } 897 while (sc->sc_owner != NULL) 898 mtx_sleep(sc, &sc->sc_mtx, 0, "gpiobuswait", 0); 899 } 900 sc->sc_owner = child; 901 GPIOBUS_UNLOCK(sc); 902 903 return (0); 904 } 905 906 static void 907 gpiobus_release_bus(device_t busdev, device_t child) 908 { 909 struct gpiobus_softc *sc; 910 911 sc = device_get_softc(busdev); 912 GPIOBUS_ASSERT_UNLOCKED(sc); 913 GPIOBUS_LOCK(sc); 914 if (sc->sc_owner == NULL) 915 panic("%s: %s releasing unowned bus.", 916 device_get_nameunit(busdev), 917 device_get_nameunit(child)); 918 if (sc->sc_owner != child) 919 panic("%s: %s trying to release bus owned by %s", 920 device_get_nameunit(busdev), 921 device_get_nameunit(child), 922 device_get_nameunit(sc->sc_owner)); 923 sc->sc_owner = NULL; 924 wakeup(sc); 925 GPIOBUS_UNLOCK(sc); 926 } 927 928 static int 929 gpiobus_pin_setflags(device_t dev, device_t child, uint32_t pin, 930 uint32_t flags) 931 { 932 struct gpiobus_softc *sc = GPIOBUS_SOFTC(dev); 933 struct gpiobus_ivar *devi = GPIOBUS_IVAR(child); 934 uint32_t caps; 935 936 if (pin >= devi->npins) 937 return (EINVAL); 938 if (GPIO_PIN_GETCAPS(sc->sc_dev, devi->pins[pin], &caps) != 0) 939 return (EINVAL); 940 if (gpio_check_flags(caps, flags) != 0) 941 return (EINVAL); 942 943 return (GPIO_PIN_SETFLAGS(sc->sc_dev, devi->pins[pin], flags)); 944 } 945 946 static int 947 gpiobus_pin_getflags(device_t dev, device_t child, uint32_t pin, 948 uint32_t *flags) 949 { 950 struct gpiobus_softc *sc = GPIOBUS_SOFTC(dev); 951 struct gpiobus_ivar *devi = GPIOBUS_IVAR(child); 952 953 if (pin >= devi->npins) 954 return (EINVAL); 955 956 return GPIO_PIN_GETFLAGS(sc->sc_dev, devi->pins[pin], flags); 957 } 958 959 static int 960 gpiobus_pin_getcaps(device_t dev, device_t child, uint32_t pin, 961 uint32_t *caps) 962 { 963 struct gpiobus_softc *sc = GPIOBUS_SOFTC(dev); 964 struct gpiobus_ivar *devi = GPIOBUS_IVAR(child); 965 966 if (pin >= devi->npins) 967 return (EINVAL); 968 969 return GPIO_PIN_GETCAPS(sc->sc_dev, devi->pins[pin], caps); 970 } 971 972 static int 973 gpiobus_pin_set(device_t dev, device_t child, uint32_t pin, 974 unsigned int value) 975 { 976 struct gpiobus_softc *sc = GPIOBUS_SOFTC(dev); 977 struct gpiobus_ivar *devi = GPIOBUS_IVAR(child); 978 979 if (pin >= devi->npins) 980 return (EINVAL); 981 982 return GPIO_PIN_SET(sc->sc_dev, devi->pins[pin], value); 983 } 984 985 static int 986 gpiobus_pin_get(device_t dev, device_t child, uint32_t pin, 987 unsigned int *value) 988 { 989 struct gpiobus_softc *sc = GPIOBUS_SOFTC(dev); 990 struct gpiobus_ivar *devi = GPIOBUS_IVAR(child); 991 992 if (pin >= devi->npins) 993 return (EINVAL); 994 995 return GPIO_PIN_GET(sc->sc_dev, devi->pins[pin], value); 996 } 997 998 static int 999 gpiobus_pin_toggle(device_t dev, device_t child, uint32_t pin) 1000 { 1001 struct gpiobus_softc *sc = GPIOBUS_SOFTC(dev); 1002 struct gpiobus_ivar *devi = GPIOBUS_IVAR(child); 1003 1004 if (pin >= devi->npins) 1005 return (EINVAL); 1006 1007 return GPIO_PIN_TOGGLE(sc->sc_dev, devi->pins[pin]); 1008 } 1009 1010 static int 1011 gpiobus_pin_getname(device_t dev, uint32_t pin, char *name) 1012 { 1013 struct gpiobus_softc *sc; 1014 1015 sc = GPIOBUS_SOFTC(dev); 1016 if (pin > sc->sc_npins) 1017 return (EINVAL); 1018 /* Did we have a name for this pin ? */ 1019 if (sc->sc_pins[pin].name != NULL) { 1020 memcpy(name, sc->sc_pins[pin].name, GPIOMAXNAME); 1021 return (0); 1022 } 1023 1024 /* Return the default pin name. */ 1025 return (GPIO_PIN_GETNAME(device_get_parent(dev), pin, name)); 1026 } 1027 1028 static int 1029 gpiobus_pin_setname(device_t dev, uint32_t pin, const char *name) 1030 { 1031 struct gpiobus_softc *sc; 1032 1033 sc = GPIOBUS_SOFTC(dev); 1034 if (pin > sc->sc_npins) 1035 return (EINVAL); 1036 if (name == NULL) 1037 return (EINVAL); 1038 /* Save the pin name. */ 1039 if (sc->sc_pins[pin].name == NULL) 1040 sc->sc_pins[pin].name = malloc(GPIOMAXNAME, M_DEVBUF, 1041 M_WAITOK | M_ZERO); 1042 strlcpy(sc->sc_pins[pin].name, name, GPIOMAXNAME); 1043 1044 return (0); 1045 } 1046 1047 static device_method_t gpiobus_methods[] = { 1048 /* Device interface */ 1049 DEVMETHOD(device_probe, gpiobus_probe), 1050 DEVMETHOD(device_attach, gpiobus_attach), 1051 DEVMETHOD(device_detach, gpiobus_detach), 1052 DEVMETHOD(device_shutdown, bus_generic_shutdown), 1053 DEVMETHOD(device_suspend, gpiobus_suspend), 1054 DEVMETHOD(device_resume, gpiobus_resume), 1055 1056 /* Bus interface */ 1057 DEVMETHOD(bus_setup_intr, bus_generic_setup_intr), 1058 DEVMETHOD(bus_config_intr, bus_generic_config_intr), 1059 DEVMETHOD(bus_teardown_intr, bus_generic_teardown_intr), 1060 DEVMETHOD(bus_delete_resource, bus_generic_rl_delete_resource), 1061 DEVMETHOD(bus_get_resource, bus_generic_rl_get_resource), 1062 DEVMETHOD(bus_set_resource, bus_generic_rl_set_resource), 1063 DEVMETHOD(bus_alloc_resource, gpiobus_alloc_resource), 1064 DEVMETHOD(bus_release_resource, gpiobus_release_resource), 1065 DEVMETHOD(bus_activate_resource, bus_generic_activate_resource), 1066 DEVMETHOD(bus_deactivate_resource, bus_generic_deactivate_resource), 1067 DEVMETHOD(bus_get_resource_list, gpiobus_get_resource_list), 1068 DEVMETHOD(bus_add_child, gpiobus_add_child), 1069 DEVMETHOD(bus_rescan, gpiobus_rescan), 1070 DEVMETHOD(bus_probe_nomatch, gpiobus_probe_nomatch), 1071 DEVMETHOD(bus_print_child, gpiobus_print_child), 1072 DEVMETHOD(bus_child_location, gpiobus_child_location), 1073 DEVMETHOD(bus_hinted_child, gpiobus_hinted_child), 1074 DEVMETHOD(bus_read_ivar, gpiobus_read_ivar), 1075 DEVMETHOD(bus_write_ivar, gpiobus_write_ivar), 1076 1077 /* GPIO protocol */ 1078 DEVMETHOD(gpiobus_acquire_bus, gpiobus_acquire_bus), 1079 DEVMETHOD(gpiobus_release_bus, gpiobus_release_bus), 1080 DEVMETHOD(gpiobus_pin_getflags, gpiobus_pin_getflags), 1081 DEVMETHOD(gpiobus_pin_getcaps, gpiobus_pin_getcaps), 1082 DEVMETHOD(gpiobus_pin_setflags, gpiobus_pin_setflags), 1083 DEVMETHOD(gpiobus_pin_get, gpiobus_pin_get), 1084 DEVMETHOD(gpiobus_pin_set, gpiobus_pin_set), 1085 DEVMETHOD(gpiobus_pin_toggle, gpiobus_pin_toggle), 1086 DEVMETHOD(gpiobus_pin_getname, gpiobus_pin_getname), 1087 DEVMETHOD(gpiobus_pin_setname, gpiobus_pin_setname), 1088 1089 DEVMETHOD_END 1090 }; 1091 1092 driver_t gpiobus_driver = { 1093 "gpiobus", 1094 gpiobus_methods, 1095 sizeof(struct gpiobus_softc) 1096 }; 1097 1098 EARLY_DRIVER_MODULE(gpiobus, gpio, gpiobus_driver, 0, 0, 1099 BUS_PASS_BUS + BUS_PASS_ORDER_MIDDLE); 1100 MODULE_VERSION(gpiobus, 1); 1101