static void vx855gpio_set(struct gpio_chip *gpio, unsigned int nr, int val) { struct vx855_gpio *vg = container_of(gpio, struct vx855_gpio, gpio); unsigned long flags; u_int32_t reg_out; /* True GPI cannot be switched to output mode */ if (nr < NR_VX855_GPI) return; spin_lock_irqsave(&vg->lock, flags); reg_out = inl(vg->io_gpo); if (nr < NR_VX855_GPInO) { if (val) reg_out |= gpo_o_bit(nr - NR_VX855_GPI); else reg_out &= ~gpo_o_bit(nr - NR_VX855_GPI); } else { if (val) reg_out |= gpio_o_bit(nr - NR_VX855_GPInO); else reg_out &= ~gpio_o_bit(nr - NR_VX855_GPInO); } outl(reg_out, vg->io_gpo); spin_unlock_irqrestore(&vg->lock, flags); }
static int vx855gpio_get(struct gpio_chip *gpio, unsigned int nr) { struct vx855_gpio *vg = container_of(gpio, struct vx855_gpio, gpio); u_int32_t reg_in; int ret = 0; if (nr < NR_VX855_GPI) { reg_in = inl(vg->io_gpi); if (reg_in & gpi_i_bit(nr)) ret = 1; } else if (nr < NR_VX855_GPInO) { /* GPO don't have an input bit, we need to read it * back from the output register */ reg_in = inl(vg->io_gpo); if (reg_in & gpo_o_bit(nr - NR_VX855_GPI)) ret = 1; } else { reg_in = inl(vg->io_gpi); if (reg_in & gpio_i_bit(nr - NR_VX855_GPInO)) ret = 1; } return ret; }
static int vx855gpio_get(struct gpio_chip *gpio, unsigned int nr) { struct vx855_gpio *vg = container_of(gpio, struct vx855_gpio, gpio); u_int32_t reg_in; int ret = 0; if (nr < NR_VX855_GPI) { reg_in = inl(vg->io_gpi); if (reg_in & gpi_i_bit(nr)) ret = 1; } else if (nr < NR_VX855_GPInO) { /* */ reg_in = inl(vg->io_gpo); if (reg_in & gpo_o_bit(nr - NR_VX855_GPI)) ret = 1; } else { reg_in = inl(vg->io_gpi); if (reg_in & gpio_i_bit(nr - NR_VX855_GPInO)) ret = 1; } return ret; }