Lines Matching refs:gpio
103 static void __iomem *bank_reg(struct aspeed_sgpio *gpio, in bank_reg() argument
109 return gpio->base + bank->val_regs + GPIO_VAL_VALUE; in bank_reg()
111 return gpio->base + bank->rdata_reg; in bank_reg()
113 return gpio->base + bank->irq_regs + GPIO_IRQ_ENABLE; in bank_reg()
115 return gpio->base + bank->irq_regs + GPIO_IRQ_TYPE0; in bank_reg()
117 return gpio->base + bank->irq_regs + GPIO_IRQ_TYPE1; in bank_reg()
119 return gpio->base + bank->irq_regs + GPIO_IRQ_TYPE2; in bank_reg()
121 return gpio->base + bank->irq_regs + GPIO_IRQ_STATUS; in bank_reg()
123 return gpio->base + bank->tolerance_regs; in bank_reg()
170 struct aspeed_sgpio *gpio = gpiochip_get_data(gc); in aspeed_sgpio_get() local
176 spin_lock_irqsave(&gpio->lock, flags); in aspeed_sgpio_get()
179 rc = !!(ioread32(bank_reg(gpio, bank, reg)) & GPIO_BIT(offset)); in aspeed_sgpio_get()
181 spin_unlock_irqrestore(&gpio->lock, flags); in aspeed_sgpio_get()
188 struct aspeed_sgpio *gpio = gpiochip_get_data(gc); in sgpio_set_value() local
198 addr_r = bank_reg(gpio, bank, reg_rdata); in sgpio_set_value()
199 addr_w = bank_reg(gpio, bank, reg_val); in sgpio_set_value()
215 struct aspeed_sgpio *gpio = gpiochip_get_data(gc); in aspeed_sgpio_set() local
218 spin_lock_irqsave(&gpio->lock, flags); in aspeed_sgpio_set()
222 spin_unlock_irqrestore(&gpio->lock, flags); in aspeed_sgpio_set()
232 struct aspeed_sgpio *gpio = gpiochip_get_data(gc); in aspeed_sgpio_dir_out() local
239 spin_lock_irqsave(&gpio->lock, flags); in aspeed_sgpio_dir_out()
241 spin_unlock_irqrestore(&gpio->lock, flags); in aspeed_sgpio_dir_out()
252 struct aspeed_sgpio **gpio, in irqd_to_aspeed_sgpio_data() argument
262 *gpio = internal; in irqd_to_aspeed_sgpio_data()
270 struct aspeed_sgpio *gpio; in aspeed_sgpio_irq_ack() local
276 irqd_to_aspeed_sgpio_data(d, &gpio, &bank, &bit, &offset); in aspeed_sgpio_irq_ack()
278 status_addr = bank_reg(gpio, bank, reg_irq_status); in aspeed_sgpio_irq_ack()
280 spin_lock_irqsave(&gpio->lock, flags); in aspeed_sgpio_irq_ack()
284 spin_unlock_irqrestore(&gpio->lock, flags); in aspeed_sgpio_irq_ack()
290 struct aspeed_sgpio *gpio; in aspeed_sgpio_irq_set_mask() local
296 irqd_to_aspeed_sgpio_data(d, &gpio, &bank, &bit, &offset); in aspeed_sgpio_irq_set_mask()
297 addr = bank_reg(gpio, bank, reg_irq_enable); in aspeed_sgpio_irq_set_mask()
299 spin_lock_irqsave(&gpio->lock, flags); in aspeed_sgpio_irq_set_mask()
309 spin_unlock_irqrestore(&gpio->lock, flags); in aspeed_sgpio_irq_set_mask()
330 struct aspeed_sgpio *gpio; in aspeed_sgpio_set_type() local
335 irqd_to_aspeed_sgpio_data(d, &gpio, &bank, &bit, &offset); in aspeed_sgpio_set_type()
358 spin_lock_irqsave(&gpio->lock, flags); in aspeed_sgpio_set_type()
360 addr = bank_reg(gpio, bank, reg_irq_type0); in aspeed_sgpio_set_type()
365 addr = bank_reg(gpio, bank, reg_irq_type1); in aspeed_sgpio_set_type()
370 addr = bank_reg(gpio, bank, reg_irq_type2); in aspeed_sgpio_set_type()
375 spin_unlock_irqrestore(&gpio->lock, flags); in aspeed_sgpio_set_type()
404 static int aspeed_sgpio_setup_irqs(struct aspeed_sgpio *gpio, in aspeed_sgpio_setup_irqs() argument
415 gpio->irq = rc; in aspeed_sgpio_setup_irqs()
421 iowrite32(0x00000000, bank_reg(gpio, bank, reg_irq_enable)); in aspeed_sgpio_setup_irqs()
423 iowrite32(0xffffffff, bank_reg(gpio, bank, reg_irq_status)); in aspeed_sgpio_setup_irqs()
426 gpio->intc.name = dev_name(&pdev->dev); in aspeed_sgpio_setup_irqs()
427 gpio->intc.irq_ack = aspeed_sgpio_irq_ack; in aspeed_sgpio_setup_irqs()
428 gpio->intc.irq_mask = aspeed_sgpio_irq_mask; in aspeed_sgpio_setup_irqs()
429 gpio->intc.irq_unmask = aspeed_sgpio_irq_unmask; in aspeed_sgpio_setup_irqs()
430 gpio->intc.irq_set_type = aspeed_sgpio_set_type; in aspeed_sgpio_setup_irqs()
432 irq = &gpio->chip.irq; in aspeed_sgpio_setup_irqs()
433 irq->chip = &gpio->intc; in aspeed_sgpio_setup_irqs()
438 irq->parent_handler_data = gpio; in aspeed_sgpio_setup_irqs()
439 irq->parents = &gpio->irq; in aspeed_sgpio_setup_irqs()
446 iowrite32(0x00000000, bank_reg(gpio, bank, reg_irq_type0)); in aspeed_sgpio_setup_irqs()
448 iowrite32(0x00000000, bank_reg(gpio, bank, reg_irq_type1)); in aspeed_sgpio_setup_irqs()
450 iowrite32(0x00000000, bank_reg(gpio, bank, reg_irq_type2)); in aspeed_sgpio_setup_irqs()
463 struct aspeed_sgpio *gpio = gpiochip_get_data(chip); in aspeed_sgpio_reset_tolerance() local
468 reg = bank_reg(gpio, to_bank(offset), reg_tolerance); in aspeed_sgpio_reset_tolerance()
470 spin_lock_irqsave(&gpio->lock, flags); in aspeed_sgpio_reset_tolerance()
481 spin_unlock_irqrestore(&gpio->lock, flags); in aspeed_sgpio_reset_tolerance()
515 struct aspeed_sgpio *gpio; in aspeed_sgpio_probe() local
519 gpio = devm_kzalloc(&pdev->dev, sizeof(*gpio), GFP_KERNEL); in aspeed_sgpio_probe()
520 if (!gpio) in aspeed_sgpio_probe()
523 gpio->base = devm_platform_ioremap_resource(pdev, 0); in aspeed_sgpio_probe()
524 if (IS_ERR(gpio->base)) in aspeed_sgpio_probe()
525 return PTR_ERR(gpio->base); in aspeed_sgpio_probe()
549 gpio->pclk = devm_clk_get(&pdev->dev, NULL); in aspeed_sgpio_probe()
550 if (IS_ERR(gpio->pclk)) { in aspeed_sgpio_probe()
552 return PTR_ERR(gpio->pclk); in aspeed_sgpio_probe()
555 apb_freq = clk_get_rate(gpio->pclk); in aspeed_sgpio_probe()
576 ASPEED_SGPIO_ENABLE, gpio->base + ASPEED_SGPIO_CTRL); in aspeed_sgpio_probe()
578 spin_lock_init(&gpio->lock); in aspeed_sgpio_probe()
580 gpio->chip.parent = &pdev->dev; in aspeed_sgpio_probe()
581 gpio->chip.ngpio = nr_gpios * 2; in aspeed_sgpio_probe()
582 gpio->chip.init_valid_mask = aspeed_sgpio_init_valid_mask; in aspeed_sgpio_probe()
583 gpio->chip.direction_input = aspeed_sgpio_dir_in; in aspeed_sgpio_probe()
584 gpio->chip.direction_output = aspeed_sgpio_dir_out; in aspeed_sgpio_probe()
585 gpio->chip.get_direction = aspeed_sgpio_get_direction; in aspeed_sgpio_probe()
586 gpio->chip.request = NULL; in aspeed_sgpio_probe()
587 gpio->chip.free = NULL; in aspeed_sgpio_probe()
588 gpio->chip.get = aspeed_sgpio_get; in aspeed_sgpio_probe()
589 gpio->chip.set = aspeed_sgpio_set; in aspeed_sgpio_probe()
590 gpio->chip.set_config = aspeed_sgpio_set_config; in aspeed_sgpio_probe()
591 gpio->chip.label = dev_name(&pdev->dev); in aspeed_sgpio_probe()
592 gpio->chip.base = -1; in aspeed_sgpio_probe()
594 aspeed_sgpio_setup_irqs(gpio, pdev); in aspeed_sgpio_probe()
596 rc = devm_gpiochip_add_data(&pdev->dev, &gpio->chip, gpio); in aspeed_sgpio_probe()