static int arizona_ldo1_remove(struct platform_device *pdev) { struct arizona_ldo1 *ldo1 = platform_get_drvdata(pdev); if (ldo1->ena_gpiod) gpiod_put(ldo1->ena_gpiod); return 0; }
/** * phylink_destroy() - cleanup and destroy the phylink instance * @pl: a pointer to a &struct phylink returned from phylink_create() * * Destroy a phylink instance. Any PHY that has been attached must have been * cleaned up via phylink_disconnect_phy() prior to calling this function. */ void phylink_destroy(struct phylink *pl) { if (pl->sfp_bus) sfp_unregister_upstream(pl->sfp_bus); if (!IS_ERR_OR_NULL(pl->link_gpio)) gpiod_put(pl->link_gpio); cancel_work_sync(&pl->resolve); kfree(pl); }
static void mmc_pwrseq_emmc_free(struct mmc_host *host) { struct mmc_pwrseq_emmc *pwrseq = container_of(host->pwrseq, struct mmc_pwrseq_emmc, pwrseq); unregister_restart_handler(&pwrseq->reset_nb); gpiod_put(pwrseq->reset_gpio); kfree(pwrseq); host->pwrseq = NULL; }
static void free_gpio(struct pi433_device *device) { int i; for (i = 0; i < NUM_DIO; i++) { /* check if gpiod is valid */ if (IS_ERR(device->gpiod[i])) continue; free_irq(device->irq_num[i], device); gpiod_put(device->gpiod[i]); } }
/* * Get the Nth GPIO number from the ACPI object. */ static int soc_button_lookup_gpio(struct device *dev, int acpi_index) { struct gpio_desc *desc; int gpio; desc = gpiod_get_index(dev, KBUILD_MODNAME, acpi_index, GPIOD_ASIS); if (IS_ERR(desc)) return PTR_ERR(desc); gpio = desc_to_gpio(desc); gpiod_put(desc); return gpio; }
static int lm363x_regulator_probe(struct platform_device *pdev) { struct ti_lmu *lmu = dev_get_drvdata(pdev->dev.parent); struct regmap *regmap = lmu->regmap; struct regulator_config cfg = { }; struct regulator_dev *rdev; struct device *dev = &pdev->dev; int id = pdev->id; struct gpio_desc *gpiod; int ret; cfg.dev = dev; cfg.regmap = regmap; /* * LM3632 LDOs can be controlled by external pin. * Register update is required if the pin is used. */ gpiod = lm363x_regulator_of_get_enable_gpio(dev, id); if (gpiod) { cfg.ena_gpiod = gpiod; ret = regmap_update_bits(regmap, LM3632_REG_BIAS_CONFIG, LM3632_EXT_EN_MASK, LM3632_EXT_EN_MASK); if (ret) { if (gpiod) gpiod_put(gpiod); dev_err(dev, "External pin err: %d\n", ret); return ret; } } rdev = devm_regulator_register(dev, &lm363x_regulator_desc[id], &cfg); if (IS_ERR(rdev)) { ret = PTR_ERR(rdev); dev_err(dev, "[%d] regulator register err: %d\n", id, ret); return ret; } return 0; }
static int mt9m114_gpio_ctrl(struct v4l2_subdev *sd, int flag) { struct i2c_client *client = v4l2_get_subdevdata(sd); struct device *dev = &client->dev; int ret; if (!camera_reset) { camera_reset = gpiod_get_index(dev, "camera_0_reset", 0); if (IS_ERR(camera_reset)) { dev_err(dev, "%s: gpiod_get_index(camera_0_reset) failed\n", __func__); ret = PTR_ERR(camera_reset); goto err_camera_reset; } } ret = gpiod_direction_output(camera_reset, 1); if (ret) { pr_err("%s: failed to set gpio direction\n", __func__); gpiod_put(camera_reset); goto err_camera_reset; } if (!camera_power_down) { camera_power_down = gpiod_get_index(dev, "camera_0_power_down", 1); if (IS_ERR(camera_power_down)) { pr_err("%s: gpiod_get_index(camera_power_down) failed\n", __func__); ret = PTR_ERR(camera_power_down); goto err_power_down; } } ret = gpiod_direction_output(camera_power_down, 0); if (ret) { pr_err("%s: failed to set gpio direction\n", __func__); gpiod_put(camera_power_down); goto err_power_down; } if (flag) { gpiod_set_value(camera_reset, 0); gpiod_set_value(camera_power_down, 1); usleep_range(1000, 2000); gpiod_set_value(camera_reset, 1); } else { gpiod_set_value(camera_power_down, 0); gpiod_put(camera_power_down); gpiod_set_value(camera_reset, 0); gpiod_put(camera_reset); camera_reset = NULL; camera_power_down = NULL; } return 0; err_camera_reset: camera_reset = NULL; return ret; err_power_down: camera_power_down = NULL; return ret; }
static int dwc3_pci_quirks(struct dwc3_pci *dwc) { struct platform_device *dwc3 = dwc->dwc3; struct pci_dev *pdev = dwc->pci; if (pdev->vendor == PCI_VENDOR_ID_AMD && pdev->device == PCI_DEVICE_ID_AMD_NL_USB) { struct property_entry properties[] = { PROPERTY_ENTRY_BOOL("snps,has-lpm-erratum"), PROPERTY_ENTRY_U8("snps,lpm-nyet-threshold", 0xf), PROPERTY_ENTRY_BOOL("snps,u2exit_lfps_quirk"), PROPERTY_ENTRY_BOOL("snps,u2ss_inp3_quirk"), PROPERTY_ENTRY_BOOL("snps,req_p1p2p3_quirk"), PROPERTY_ENTRY_BOOL("snps,del_p1p2p3_quirk"), PROPERTY_ENTRY_BOOL("snps,del_phy_power_chg_quirk"), PROPERTY_ENTRY_BOOL("snps,lfps_filter_quirk"), PROPERTY_ENTRY_BOOL("snps,rx_detect_poll_quirk"), PROPERTY_ENTRY_BOOL("snps,tx_de_emphasis_quirk"), PROPERTY_ENTRY_U8("snps,tx_de_emphasis", 1), /* * FIXME these quirks should be removed when AMD NL * tapes out */ PROPERTY_ENTRY_BOOL("snps,disable_scramble_quirk"), PROPERTY_ENTRY_BOOL("snps,dis_u3_susphy_quirk"), PROPERTY_ENTRY_BOOL("snps,dis_u2_susphy_quirk"), PROPERTY_ENTRY_BOOL("linux,sysdev_is_parent"), { }, }; return platform_device_add_properties(dwc3, properties); } if (pdev->vendor == PCI_VENDOR_ID_INTEL) { int ret; struct property_entry properties[] = { PROPERTY_ENTRY_STRING("dr_mode", "peripheral"), PROPERTY_ENTRY_BOOL("linux,sysdev_is_parent"), { } }; ret = platform_device_add_properties(dwc3, properties); if (ret < 0) return ret; if (pdev->device == PCI_DEVICE_ID_INTEL_BXT || pdev->device == PCI_DEVICE_ID_INTEL_BXT_M) { guid_parse(PCI_INTEL_BXT_DSM_GUID, &dwc->guid); dwc->has_dsm_for_pm = true; } if (pdev->device == PCI_DEVICE_ID_INTEL_BYT) { struct gpio_desc *gpio; ret = devm_acpi_dev_add_driver_gpios(&pdev->dev, acpi_dwc3_byt_gpios); if (ret) dev_dbg(&pdev->dev, "failed to add mapping table\n"); /* * These GPIOs will turn on the USB2 PHY. Note that we have to * put the gpio descriptors again here because the phy driver * might want to grab them, too. */ gpio = gpiod_get_optional(&pdev->dev, "cs", GPIOD_OUT_LOW); if (IS_ERR(gpio)) return PTR_ERR(gpio); gpiod_set_value_cansleep(gpio, 1); gpiod_put(gpio); gpio = gpiod_get_optional(&pdev->dev, "reset", GPIOD_OUT_LOW); if (IS_ERR(gpio)) return PTR_ERR(gpio); if (gpio) { gpiod_set_value_cansleep(gpio, 1); gpiod_put(gpio); usleep_range(10000, 11000); } } } if (pdev->vendor == PCI_VENDOR_ID_SYNOPSYS && (pdev->device == PCI_DEVICE_ID_SYNOPSYS_HAPSUSB3 || pdev->device == PCI_DEVICE_ID_SYNOPSYS_HAPSUSB3_AXI || pdev->device == PCI_DEVICE_ID_SYNOPSYS_HAPSUSB31)) { struct property_entry properties[] = { PROPERTY_ENTRY_BOOL("snps,usb3_lpm_capable"), PROPERTY_ENTRY_BOOL("snps,has-lpm-erratum"), PROPERTY_ENTRY_BOOL("snps,dis_enblslpm_quirk"), PROPERTY_ENTRY_BOOL("linux,sysdev_is_parent"), { }, }; return platform_device_add_properties(dwc3, properties); } return 0; }
static void devm_gpiod_release(struct device *dev, void *res) { struct gpio_desc **desc = res; gpiod_put(*desc); }
static struct clk *clk_register_gpio(struct device *dev, const char *name, const char * const *parent_names, u8 num_parents, unsigned gpio, bool active_low, unsigned long flags, const struct clk_ops *clk_gpio_ops) { struct clk_gpio *clk_gpio; struct clk *clk; struct clk_init_data init = {}; unsigned long gpio_flags; int err; if (dev) clk_gpio = devm_kzalloc(dev, sizeof(*clk_gpio), GFP_KERNEL); else clk_gpio = kzalloc(sizeof(*clk_gpio), GFP_KERNEL); if (!clk_gpio) return ERR_PTR(-ENOMEM); if (active_low) gpio_flags = GPIOF_ACTIVE_LOW | GPIOF_OUT_INIT_HIGH; else gpio_flags = GPIOF_OUT_INIT_LOW; if (dev) err = devm_gpio_request_one(dev, gpio, gpio_flags, name); else err = gpio_request_one(gpio, gpio_flags, name); if (err) { if (err != -EPROBE_DEFER) pr_err("%s: %s: Error requesting clock control gpio %u\n", __func__, name, gpio); if (!dev) kfree(clk_gpio); return ERR_PTR(err); } init.name = name; init.ops = clk_gpio_ops; init.flags = flags | CLK_IS_BASIC; init.parent_names = parent_names; init.num_parents = num_parents; clk_gpio->gpiod = gpio_to_desc(gpio); clk_gpio->hw.init = &init; if (dev) clk = devm_clk_register(dev, &clk_gpio->hw); else clk = clk_register(NULL, &clk_gpio->hw); if (!IS_ERR(clk)) return clk; if (!dev) { gpiod_put(clk_gpio->gpiod); kfree(clk_gpio); } return clk; }
static int __init my_init(void) { int status = 0; struct i2c_smbus_alert_setup setup = { .alert_edge_triggered = 1, }; struct i2c_adapter *adapter = i2c_get_adapter(6); if (!adapter) { pr_err("Failed to find i2c adapter #%d\n", 6); status = -1; goto fail; } if (!gpio_is_valid(gpioNum)) { pr_err("GPIO number %d is not valid\n", gpioNum); goto fail; } status = gpio_request_one(gpioNum, GPIOF_DIR_IN, "smbus_alert"); if (status < 0) { pr_err("GPIO allocation failed, result %d\n", status); goto fail; } setup.irq = gpio_to_irq(gpioNum); if (setup.irq < 0) { pr_err("Failed to get gpio interrupt, err is %d\n", setup.irq); goto release_gpio; } #if 1 alert_client = i2c_setup_smbus_alert(adapter, &setup); if (!alert_client) { pr_err("Failed to register smbus alert device.\n"); goto release_gpio; } i2c_put_adapter(adapter); #else status = request_threaded_irq(setup.irq, NULL, my_handler, IRQF_TRIGGER_FALLING | IRQF_ONESHOT, "smartio_smbus", &gpioNum); if (status < 0) { pr_err("Failed to install interrupt handlert, err is %d\n", status); goto release_gpio; } #endif pr_warn("Done setting up smbus alert\n"); return status; release_gpio: gpio_free(gpioNum); release_adapter: i2c_put_adapter(adapter); fail: pr_err("Failed setting up smbus alert\n"); return status; } module_init(my_init); static void __exit my_cleanup(void) { #if 0 i2c_unregister_device(alert_client); gpiod_put(gpio); #endif gpio_free(gpioNum); pr_warn("Removed smbus alert\n"); }
static int dwc3_pci_quirks(struct pci_dev *pdev) { if (pdev->vendor == PCI_VENDOR_ID_AMD && pdev->device == PCI_DEVICE_ID_AMD_NL_USB) { struct dwc3_platform_data pdata; memset(&pdata, 0, sizeof(pdata)); pdata.has_lpm_erratum = true; pdata.lpm_nyet_threshold = 0xf; pdata.u2exit_lfps_quirk = true; pdata.u2ss_inp3_quirk = true; pdata.req_p1p2p3_quirk = true; pdata.del_p1p2p3_quirk = true; pdata.del_phy_power_chg_quirk = true; pdata.lfps_filter_quirk = true; pdata.rx_detect_poll_quirk = true; pdata.tx_de_emphasis_quirk = true; pdata.tx_de_emphasis = 1; /* * FIXME these quirks should be removed when AMD NL * taps out */ pdata.disable_scramble_quirk = true; pdata.dis_u3_susphy_quirk = true; pdata.dis_u2_susphy_quirk = true; return platform_device_add_data(pci_get_drvdata(pdev), &pdata, sizeof(pdata)); } if (pdev->vendor == PCI_VENDOR_ID_INTEL && pdev->device == PCI_DEVICE_ID_INTEL_BYT) { struct gpio_desc *gpio; acpi_dev_add_driver_gpios(ACPI_COMPANION(&pdev->dev), acpi_dwc3_byt_gpios); /* * These GPIOs will turn on the USB2 PHY. Note that we have to * put the gpio descriptors again here because the phy driver * might want to grab them, too. */ gpio = gpiod_get_optional(&pdev->dev, "cs", GPIOD_OUT_LOW); if (IS_ERR(gpio)) return PTR_ERR(gpio); gpiod_set_value_cansleep(gpio, 1); gpiod_put(gpio); gpio = gpiod_get_optional(&pdev->dev, "reset", GPIOD_OUT_LOW); if (IS_ERR(gpio)) return PTR_ERR(gpio); if (gpio) { gpiod_set_value_cansleep(gpio, 1); gpiod_put(gpio); usleep_range(10000, 11000); } } if (pdev->vendor == PCI_VENDOR_ID_SYNOPSYS && (pdev->device == PCI_DEVICE_ID_SYNOPSYS_HAPSUSB3 || pdev->device == PCI_DEVICE_ID_SYNOPSYS_HAPSUSB3_AXI || pdev->device == PCI_DEVICE_ID_SYNOPSYS_HAPSUSB31)) { struct dwc3_platform_data pdata; memset(&pdata, 0, sizeof(pdata)); pdata.usb3_lpm_capable = true; pdata.has_lpm_erratum = true; pdata.dis_enblslpm_quirk = true; return platform_device_add_data(pci_get_drvdata(pdev), &pdata, sizeof(pdata)); } return 0; }
static int setup_gpio(struct pi433_device *device) { char name[5]; int retval; int i; const irq_handler_t DIO_irq_handler[NUM_DIO] = { DIO0_irq_handler, DIO1_irq_handler }; for (i = 0; i < NUM_DIO; i++) { /* "construct" name and get the gpio descriptor */ snprintf(name, sizeof(name), "DIO%d", i); device->gpiod[i] = gpiod_get(&device->spi->dev, name, 0 /*GPIOD_IN*/); if (device->gpiod[i] == ERR_PTR(-ENOENT)) { dev_dbg(&device->spi->dev, "Could not find entry for %s. Ignoring.", name); continue; } if (device->gpiod[i] == ERR_PTR(-EBUSY)) dev_dbg(&device->spi->dev, "%s is busy.", name); if (IS_ERR(device->gpiod[i])) { retval = PTR_ERR(device->gpiod[i]); /* release already allocated gpios */ for (i--; i >= 0; i--) { free_irq(device->irq_num[i], device); gpiod_put(device->gpiod[i]); } return retval; } /* configure the pin */ gpiod_unexport(device->gpiod[i]); retval = gpiod_direction_input(device->gpiod[i]); if (retval) return retval; /* configure irq */ device->irq_num[i] = gpiod_to_irq(device->gpiod[i]); if (device->irq_num[i] < 0) { device->gpiod[i] = ERR_PTR(-EINVAL); return device->irq_num[i]; } retval = request_irq(device->irq_num[i], DIO_irq_handler[i], 0, /* flags */ name, device); if (retval) return retval; dev_dbg(&device->spi->dev, "%s successfully configured", name); } return 0; }