Lines Matching refs:sch

43 static unsigned sch_gpio_offset(struct sch_gpio *sch, unsigned gpio,  in sch_gpio_offset()  argument
48 if (gpio >= sch->resume_base) { in sch_gpio_offset()
49 gpio -= sch->resume_base; in sch_gpio_offset()
56 static unsigned sch_gpio_bit(struct sch_gpio *sch, unsigned gpio) in sch_gpio_bit() argument
58 if (gpio >= sch->resume_base) in sch_gpio_bit()
59 gpio -= sch->resume_base; in sch_gpio_bit()
63 static int sch_gpio_reg_get(struct sch_gpio *sch, unsigned gpio, unsigned reg) in sch_gpio_reg_get() argument
68 offset = sch_gpio_offset(sch, gpio, reg); in sch_gpio_reg_get()
69 bit = sch_gpio_bit(sch, gpio); in sch_gpio_reg_get()
71 reg_val = !!(inb(sch->iobase + offset) & BIT(bit)); in sch_gpio_reg_get()
76 static void sch_gpio_reg_set(struct sch_gpio *sch, unsigned gpio, unsigned reg, in sch_gpio_reg_set() argument
82 offset = sch_gpio_offset(sch, gpio, reg); in sch_gpio_reg_set()
83 bit = sch_gpio_bit(sch, gpio); in sch_gpio_reg_set()
85 reg_val = inb(sch->iobase + offset); in sch_gpio_reg_set()
88 outb(reg_val | BIT(bit), sch->iobase + offset); in sch_gpio_reg_set()
90 outb((reg_val & ~BIT(bit)), sch->iobase + offset); in sch_gpio_reg_set()
95 struct sch_gpio *sch = gpiochip_get_data(gc); in sch_gpio_direction_in() local
97 spin_lock(&sch->lock); in sch_gpio_direction_in()
98 sch_gpio_reg_set(sch, gpio_num, GIO, 1); in sch_gpio_direction_in()
99 spin_unlock(&sch->lock); in sch_gpio_direction_in()
105 struct sch_gpio *sch = gpiochip_get_data(gc); in sch_gpio_get() local
106 return sch_gpio_reg_get(sch, gpio_num, GLV); in sch_gpio_get()
111 struct sch_gpio *sch = gpiochip_get_data(gc); in sch_gpio_set() local
113 spin_lock(&sch->lock); in sch_gpio_set()
114 sch_gpio_reg_set(sch, gpio_num, GLV, val); in sch_gpio_set()
115 spin_unlock(&sch->lock); in sch_gpio_set()
121 struct sch_gpio *sch = gpiochip_get_data(gc); in sch_gpio_direction_out() local
123 spin_lock(&sch->lock); in sch_gpio_direction_out()
124 sch_gpio_reg_set(sch, gpio_num, GIO, 0); in sch_gpio_direction_out()
125 spin_unlock(&sch->lock); in sch_gpio_direction_out()
142 struct sch_gpio *sch = gpiochip_get_data(gc); in sch_gpio_get_direction() local
144 return sch_gpio_reg_get(sch, gpio_num, GIO); in sch_gpio_get_direction()
159 struct sch_gpio *sch; in sch_gpio_probe() local
162 sch = devm_kzalloc(&pdev->dev, sizeof(*sch), GFP_KERNEL); in sch_gpio_probe()
163 if (!sch) in sch_gpio_probe()
174 spin_lock_init(&sch->lock); in sch_gpio_probe()
175 sch->iobase = res->start; in sch_gpio_probe()
176 sch->chip = sch_gpio_chip; in sch_gpio_probe()
177 sch->chip.label = dev_name(&pdev->dev); in sch_gpio_probe()
178 sch->chip.parent = &pdev->dev; in sch_gpio_probe()
182 sch->core_base = 0; in sch_gpio_probe()
183 sch->resume_base = 10; in sch_gpio_probe()
184 sch->chip.ngpio = 14; in sch_gpio_probe()
191 sch_gpio_reg_set(sch, 8, GEN, 1); in sch_gpio_probe()
192 sch_gpio_reg_set(sch, 9, GEN, 1); in sch_gpio_probe()
197 sch_gpio_reg_set(sch, 13, GEN, 1); in sch_gpio_probe()
201 sch->core_base = 0; in sch_gpio_probe()
202 sch->resume_base = 5; in sch_gpio_probe()
203 sch->chip.ngpio = 14; in sch_gpio_probe()
207 sch->core_base = 0; in sch_gpio_probe()
208 sch->resume_base = 21; in sch_gpio_probe()
209 sch->chip.ngpio = 30; in sch_gpio_probe()
213 sch->core_base = 0; in sch_gpio_probe()
214 sch->resume_base = 2; in sch_gpio_probe()
215 sch->chip.ngpio = 8; in sch_gpio_probe()
222 platform_set_drvdata(pdev, sch); in sch_gpio_probe()
224 return devm_gpiochip_add_data(&pdev->dev, &sch->chip, sch); in sch_gpio_probe()