Blame view
include/linux/nsc_gpio.h
1.42 KB
b24413180 License cleanup: ... |
1 |
/* SPDX-License-Identifier: GPL-2.0 */ |
fe3a168a2 [PATCH] chardev: ... |
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
/** nsc_gpio.c National Semiconductor GPIO common access methods. struct nsc_gpio_ops abstracts the low-level access operations for the GPIO units on 2 NSC chip families; the GEODE integrated CPU, and the PC-8736[03456] integrated PC-peripheral chips. The GPIO units on these chips have the same pin architecture, but the access methods differ. Thus, scx200_gpio and pc8736x_gpio implement their own versions of these routines; and use the common file-operations routines implemented in nsc_gpio module. Copyright (c) 2005 Jim Cromie <jim.cromie@gmail.com> NB: this work was tested on the Geode SC-1100 and PC-87366 chips. NSC sold the GEODE line to AMD, and the PC-8736x line to Winbond. */ struct nsc_gpio_ops { struct module* owner; u32 (*gpio_config) (unsigned iminor, u32 mask, u32 bits); |
f31000e57 [PATCH] chardev: ... |
26 |
void (*gpio_dump) (struct nsc_gpio_ops *amp, unsigned iminor); |
fe3a168a2 [PATCH] chardev: ... |
27 28 |
int (*gpio_get) (unsigned iminor); void (*gpio_set) (unsigned iminor, int state); |
fe3a168a2 [PATCH] chardev: ... |
29 30 |
void (*gpio_change) (unsigned iminor); int (*gpio_current) (unsigned iminor); |
f31000e57 [PATCH] chardev: ... |
31 |
struct device* dev; /* for dev_dbg() support, set in init */ |
fe3a168a2 [PATCH] chardev: ... |
32 |
}; |
1a66fdf08 [PATCH] chardev: ... |
33 34 35 36 37 |
extern ssize_t nsc_gpio_write(struct file *file, const char __user *data, size_t len, loff_t *ppos); extern ssize_t nsc_gpio_read(struct file *file, char __user *buf, size_t len, loff_t *ppos); |
f31000e57 [PATCH] chardev: ... |
38 39 |
extern void nsc_gpio_dump(struct nsc_gpio_ops *amp, unsigned index); |