xref: /openbmc/linux/tools/lib/api/fd/array.h (revision d87c25e8f4051f813762da6a182c57f246b17441)
1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
21b85337dSArnaldo Carvalho de Melo #ifndef __API_FD_ARRAY__
31b85337dSArnaldo Carvalho de Melo #define __API_FD_ARRAY__
41b85337dSArnaldo Carvalho de Melo 
51b85337dSArnaldo Carvalho de Melo #include <stdio.h>
61b85337dSArnaldo Carvalho de Melo 
71b85337dSArnaldo Carvalho de Melo struct pollfd;
81b85337dSArnaldo Carvalho de Melo 
92171a925SArnaldo Carvalho de Melo /**
102171a925SArnaldo Carvalho de Melo  * struct fdarray: Array of file descriptors
112171a925SArnaldo Carvalho de Melo  *
122171a925SArnaldo Carvalho de Melo  * @priv: Per array entry priv area, users should access just its contents,
132171a925SArnaldo Carvalho de Melo  *	  not set it to anything, as it is kept in synch with @entries, being
142171a925SArnaldo Carvalho de Melo  *	  realloc'ed, * for instance, in fdarray__{grow,filter}.
152171a925SArnaldo Carvalho de Melo  *
162171a925SArnaldo Carvalho de Melo  *	  I.e. using 'fda->priv[N].idx = * value' where N < fda->nr is ok,
172171a925SArnaldo Carvalho de Melo  *	  but doing 'fda->priv = malloc(M)' is not allowed.
182171a925SArnaldo Carvalho de Melo  */
191b85337dSArnaldo Carvalho de Melo struct fdarray {
201b85337dSArnaldo Carvalho de Melo 	int	       nr;
211b85337dSArnaldo Carvalho de Melo 	int	       nr_alloc;
221b85337dSArnaldo Carvalho de Melo 	int	       nr_autogrow;
231b85337dSArnaldo Carvalho de Melo 	struct pollfd *entries;
24ab4c1f9fSAlexey Budankov 	struct priv {
252171a925SArnaldo Carvalho de Melo 		union {
262171a925SArnaldo Carvalho de Melo 			int    idx;
272b438347SWang Nan 			void   *ptr;
28ab4c1f9fSAlexey Budankov 		};
29ab4c1f9fSAlexey Budankov 		unsigned int flags;
302171a925SArnaldo Carvalho de Melo 	} *priv;
311b85337dSArnaldo Carvalho de Melo };
321b85337dSArnaldo Carvalho de Melo 
33ab4c1f9fSAlexey Budankov enum fdarray_flags {
34ab4c1f9fSAlexey Budankov 	fdarray_flag__default	    = 0x00000000,
35ab4c1f9fSAlexey Budankov 	fdarray_flag__nonfilterable = 0x00000001
36ab4c1f9fSAlexey Budankov };
37ab4c1f9fSAlexey Budankov 
381b85337dSArnaldo Carvalho de Melo void fdarray__init(struct fdarray *fda, int nr_autogrow);
391b85337dSArnaldo Carvalho de Melo void fdarray__exit(struct fdarray *fda);
401b85337dSArnaldo Carvalho de Melo 
411b85337dSArnaldo Carvalho de Melo struct fdarray *fdarray__new(int nr_alloc, int nr_autogrow);
421b85337dSArnaldo Carvalho de Melo void fdarray__delete(struct fdarray *fda);
431b85337dSArnaldo Carvalho de Melo 
44ab4c1f9fSAlexey Budankov int fdarray__add(struct fdarray *fda, int fd, short revents, enum fdarray_flags flags);
45*d87c25e8SAlexey Bayduraev int fdarray__dup_entry_from(struct fdarray *fda, int pos, struct fdarray *from);
461b85337dSArnaldo Carvalho de Melo int fdarray__poll(struct fdarray *fda, int timeout);
472171a925SArnaldo Carvalho de Melo int fdarray__filter(struct fdarray *fda, short revents,
48258e4bfcSWang Nan 		    void (*entry_destructor)(struct fdarray *fda, int fd, void *arg),
49258e4bfcSWang Nan 		    void *arg);
501b85337dSArnaldo Carvalho de Melo int fdarray__grow(struct fdarray *fda, int extra);
511b85337dSArnaldo Carvalho de Melo int fdarray__fprintf(struct fdarray *fda, FILE *fp);
521b85337dSArnaldo Carvalho de Melo 
531b85337dSArnaldo Carvalho de Melo static inline int fdarray__available_entries(struct fdarray *fda)
541b85337dSArnaldo Carvalho de Melo {
551b85337dSArnaldo Carvalho de Melo 	return fda->nr_alloc - fda->nr;
561b85337dSArnaldo Carvalho de Melo }
571b85337dSArnaldo Carvalho de Melo 
581b85337dSArnaldo Carvalho de Melo #endif /* __API_FD_ARRAY__ */
59