• Home
  • Raw
  • Download

Lines Matching +full:reg +full:- +full:offset

38 static int palmas_gpio_get(struct gpio_chip *gc, unsigned offset)  in palmas_gpio_get()  argument
41 struct palmas *palmas = pg->palmas; in palmas_gpio_get()
44 unsigned int reg; in palmas_gpio_get() local
45 int gpio16 = (offset/8); in palmas_gpio_get()
47 offset %= 8; in palmas_gpio_get()
48 reg = (gpio16) ? PALMAS_GPIO_DATA_DIR2 : PALMAS_GPIO_DATA_DIR; in palmas_gpio_get()
50 ret = palmas_read(palmas, PALMAS_GPIO_BASE, reg, &val); in palmas_gpio_get()
52 dev_err(gc->parent, "Reg 0x%02x read failed, %d\n", reg, ret); in palmas_gpio_get()
56 if (val & BIT(offset)) in palmas_gpio_get()
57 reg = (gpio16) ? PALMAS_GPIO_DATA_OUT2 : PALMAS_GPIO_DATA_OUT; in palmas_gpio_get()
59 reg = (gpio16) ? PALMAS_GPIO_DATA_IN2 : PALMAS_GPIO_DATA_IN; in palmas_gpio_get()
61 ret = palmas_read(palmas, PALMAS_GPIO_BASE, reg, &val); in palmas_gpio_get()
63 dev_err(gc->parent, "Reg 0x%02x read failed, %d\n", reg, ret); in palmas_gpio_get()
66 return !!(val & BIT(offset)); in palmas_gpio_get()
69 static void palmas_gpio_set(struct gpio_chip *gc, unsigned offset, in palmas_gpio_set() argument
73 struct palmas *palmas = pg->palmas; in palmas_gpio_set()
75 unsigned int reg; in palmas_gpio_set() local
76 int gpio16 = (offset/8); in palmas_gpio_set()
78 offset %= 8; in palmas_gpio_set()
80 reg = (value) ? in palmas_gpio_set()
83 reg = (value) ? in palmas_gpio_set()
86 ret = palmas_write(palmas, PALMAS_GPIO_BASE, reg, BIT(offset)); in palmas_gpio_set()
88 dev_err(gc->parent, "Reg 0x%02x write failed, %d\n", reg, ret); in palmas_gpio_set()
91 static int palmas_gpio_output(struct gpio_chip *gc, unsigned offset, in palmas_gpio_output() argument
95 struct palmas *palmas = pg->palmas; in palmas_gpio_output()
97 unsigned int reg; in palmas_gpio_output() local
98 int gpio16 = (offset/8); in palmas_gpio_output()
100 offset %= 8; in palmas_gpio_output()
101 reg = (gpio16) ? PALMAS_GPIO_DATA_DIR2 : PALMAS_GPIO_DATA_DIR; in palmas_gpio_output()
104 palmas_gpio_set(gc, offset, value); in palmas_gpio_output()
106 ret = palmas_update_bits(palmas, PALMAS_GPIO_BASE, reg, in palmas_gpio_output()
107 BIT(offset), BIT(offset)); in palmas_gpio_output()
109 dev_err(gc->parent, "Reg 0x%02x update failed, %d\n", reg, in palmas_gpio_output()
114 static int palmas_gpio_input(struct gpio_chip *gc, unsigned offset) in palmas_gpio_input() argument
117 struct palmas *palmas = pg->palmas; in palmas_gpio_input()
119 unsigned int reg; in palmas_gpio_input() local
120 int gpio16 = (offset/8); in palmas_gpio_input()
122 offset %= 8; in palmas_gpio_input()
123 reg = (gpio16) ? PALMAS_GPIO_DATA_DIR2 : PALMAS_GPIO_DATA_DIR; in palmas_gpio_input()
125 ret = palmas_update_bits(palmas, PALMAS_GPIO_BASE, reg, BIT(offset), 0); in palmas_gpio_input()
127 dev_err(gc->parent, "Reg 0x%02x update failed, %d\n", reg, in palmas_gpio_input()
132 static int palmas_gpio_to_irq(struct gpio_chip *gc, unsigned offset) in palmas_gpio_to_irq() argument
135 struct palmas *palmas = pg->palmas; in palmas_gpio_to_irq()
137 return palmas_irq_get_virq(palmas, PALMAS_GPIO_0_IRQ + offset); in palmas_gpio_to_irq()
149 { .compatible = "ti,palmas-gpio", .data = &palmas_dev_data,},
150 { .compatible = "ti,tps65913-gpio", .data = &palmas_dev_data,},
151 { .compatible = "ti,tps65914-gpio", .data = &palmas_dev_data,},
152 { .compatible = "ti,tps80036-gpio", .data = &tps80036_dev_data,},
158 struct palmas *palmas = dev_get_drvdata(pdev->dev.parent); in palmas_gpio_probe()
164 dev_data = of_device_get_match_data(&pdev->dev); in palmas_gpio_probe()
168 palmas_gpio = devm_kzalloc(&pdev->dev, in palmas_gpio_probe()
171 return -ENOMEM; in palmas_gpio_probe()
173 palmas_gpio->palmas = palmas; in palmas_gpio_probe()
174 palmas_gpio->gpio_chip.owner = THIS_MODULE; in palmas_gpio_probe()
175 palmas_gpio->gpio_chip.label = dev_name(&pdev->dev); in palmas_gpio_probe()
176 palmas_gpio->gpio_chip.ngpio = dev_data->ngpio; in palmas_gpio_probe()
177 palmas_gpio->gpio_chip.can_sleep = true; in palmas_gpio_probe()
178 palmas_gpio->gpio_chip.direction_input = palmas_gpio_input; in palmas_gpio_probe()
179 palmas_gpio->gpio_chip.direction_output = palmas_gpio_output; in palmas_gpio_probe()
180 palmas_gpio->gpio_chip.to_irq = palmas_gpio_to_irq; in palmas_gpio_probe()
181 palmas_gpio->gpio_chip.set = palmas_gpio_set; in palmas_gpio_probe()
182 palmas_gpio->gpio_chip.get = palmas_gpio_get; in palmas_gpio_probe()
183 palmas_gpio->gpio_chip.parent = &pdev->dev; in palmas_gpio_probe()
185 palmas_gpio->gpio_chip.of_node = pdev->dev.of_node; in palmas_gpio_probe()
187 palmas_pdata = dev_get_platdata(palmas->dev); in palmas_gpio_probe()
188 if (palmas_pdata && palmas_pdata->gpio_base) in palmas_gpio_probe()
189 palmas_gpio->gpio_chip.base = palmas_pdata->gpio_base; in palmas_gpio_probe()
191 palmas_gpio->gpio_chip.base = -1; in palmas_gpio_probe()
193 ret = devm_gpiochip_add_data(&pdev->dev, &palmas_gpio->gpio_chip, in palmas_gpio_probe()
196 dev_err(&pdev->dev, "Could not register gpiochip, %d\n", ret); in palmas_gpio_probe()
205 .driver.name = "palmas-gpio",