Thomas Gleixner | 8266496 | 2019-06-01 10:08:51 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | /* |
| 3 | * transport_class.h - a generic container for all transport classes |
| 4 | * |
| 5 | * Copyright (c) 2005 - James Bottomley <James.Bottomley@steeleye.com> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 6 | */ |
| 7 | |
| 8 | #ifndef _TRANSPORT_CLASS_H_ |
| 9 | #define _TRANSPORT_CLASS_H_ |
| 10 | |
| 11 | #include <linux/device.h> |
Paul Gortmaker | 187f188 | 2011-11-23 20:12:59 -0500 | [diff] [blame] | 12 | #include <linux/bug.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 13 | #include <linux/attribute_container.h> |
| 14 | |
James Bottomley | d0a7e57 | 2005-08-14 17:09:01 -0500 | [diff] [blame] | 15 | struct transport_container; |
| 16 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 17 | struct transport_class { |
| 18 | struct class class; |
James Bottomley | d0a7e57 | 2005-08-14 17:09:01 -0500 | [diff] [blame] | 19 | int (*setup)(struct transport_container *, struct device *, |
Tony Jones | ee959b0 | 2008-02-22 00:13:36 +0100 | [diff] [blame] | 20 | struct device *); |
James Bottomley | d0a7e57 | 2005-08-14 17:09:01 -0500 | [diff] [blame] | 21 | int (*configure)(struct transport_container *, struct device *, |
Tony Jones | ee959b0 | 2008-02-22 00:13:36 +0100 | [diff] [blame] | 22 | struct device *); |
James Bottomley | d0a7e57 | 2005-08-14 17:09:01 -0500 | [diff] [blame] | 23 | int (*remove)(struct transport_container *, struct device *, |
Tony Jones | ee959b0 | 2008-02-22 00:13:36 +0100 | [diff] [blame] | 24 | struct device *); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 25 | }; |
| 26 | |
| 27 | #define DECLARE_TRANSPORT_CLASS(cls, nm, su, rm, cfg) \ |
| 28 | struct transport_class cls = { \ |
| 29 | .class = { \ |
| 30 | .name = nm, \ |
| 31 | }, \ |
| 32 | .setup = su, \ |
| 33 | .remove = rm, \ |
| 34 | .configure = cfg, \ |
| 35 | } |
| 36 | |
| 37 | |
| 38 | struct anon_transport_class { |
| 39 | struct transport_class tclass; |
| 40 | struct attribute_container container; |
| 41 | }; |
| 42 | |
| 43 | #define DECLARE_ANON_TRANSPORT_CLASS(cls, mtch, cfg) \ |
| 44 | struct anon_transport_class cls = { \ |
| 45 | .tclass = { \ |
| 46 | .configure = cfg, \ |
| 47 | }, \ |
| 48 | . container = { \ |
| 49 | .match = mtch, \ |
| 50 | }, \ |
| 51 | } |
| 52 | |
| 53 | #define class_to_transport_class(x) \ |
| 54 | container_of(x, struct transport_class, class) |
| 55 | |
| 56 | struct transport_container { |
| 57 | struct attribute_container ac; |
David Brownell | a4dbd67 | 2009-06-24 10:06:31 -0700 | [diff] [blame] | 58 | const struct attribute_group *statistics; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 59 | }; |
| 60 | |
| 61 | #define attribute_container_to_transport_container(x) \ |
| 62 | container_of(x, struct transport_container, ac) |
| 63 | |
| 64 | void transport_remove_device(struct device *); |
Gabriel Krisman Bertazi | cd7ea70 | 2020-01-06 13:58:16 -0500 | [diff] [blame] | 65 | int transport_add_device(struct device *); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 66 | void transport_setup_device(struct device *); |
| 67 | void transport_configure_device(struct device *); |
| 68 | void transport_destroy_device(struct device *); |
| 69 | |
Gabriel Krisman Bertazi | cd7ea70 | 2020-01-06 13:58:16 -0500 | [diff] [blame] | 70 | static inline int |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 71 | transport_register_device(struct device *dev) |
| 72 | { |
| 73 | transport_setup_device(dev); |
Gabriel Krisman Bertazi | cd7ea70 | 2020-01-06 13:58:16 -0500 | [diff] [blame] | 74 | return transport_add_device(dev); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 75 | } |
| 76 | |
| 77 | static inline void |
| 78 | transport_unregister_device(struct device *dev) |
| 79 | { |
| 80 | transport_remove_device(dev); |
| 81 | transport_destroy_device(dev); |
| 82 | } |
| 83 | |
| 84 | static inline int transport_container_register(struct transport_container *tc) |
| 85 | { |
| 86 | return attribute_container_register(&tc->ac); |
| 87 | } |
| 88 | |
James Bottomley | 2f3edc69 | 2008-04-02 10:05:48 -0500 | [diff] [blame] | 89 | static inline void transport_container_unregister(struct transport_container *tc) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 90 | { |
James Bottomley | 2f3edc69 | 2008-04-02 10:05:48 -0500 | [diff] [blame] | 91 | if (unlikely(attribute_container_unregister(&tc->ac))) |
| 92 | BUG(); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 93 | } |
| 94 | |
| 95 | int transport_class_register(struct transport_class *); |
| 96 | int anon_transport_class_register(struct anon_transport_class *); |
| 97 | void transport_class_unregister(struct transport_class *); |
| 98 | void anon_transport_class_unregister(struct anon_transport_class *); |
| 99 | |
| 100 | |
| 101 | #endif |