blob: 3dd2589293e0ab4cbf4cee03ca61a5dbfb88fdea (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
/*
* Copyright (C) 2013-2015 Kay Sievers
* Copyright (C) 2013-2015 Greg Kroah-Hartman <gregkh@linuxfoundation.org>
* Copyright (C) 2013-2015 Daniel Mack <daniel@zonque.org>
* Copyright (C) 2013-2015 David Herrmann <dh.herrmann@gmail.com>
* Copyright (C) 2013-2015 Linux Foundation
* Copyright (C) 2014-2015 Djalal Harouni <tixxdz@opendz.org>
*
* kdbus is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the
* Free Software Foundation; either version 2.1 of the License, or (at
* your option) any later version.
*/
#ifndef __KDBUS_NAMES_H
#define __KDBUS_NAMES_H
#include <linux/hashtable.h>
#include <linux/rwsem.h>
/**
* struct kdbus_name_registry - names registered for a bus
* @entries_hash: Map of entries
* @lock: Registry data lock
* @name_seq_last: Last used sequence number to assign to a name entry
*/
struct kdbus_name_registry {
DECLARE_HASHTABLE(entries_hash, 8);
struct rw_semaphore rwlock;
u64 name_seq_last;
};
/**
* struct kdbus_name_entry - well-know name entry
* @name_id: Sequence number of name entry to be able to uniquely
* identify a name over its registration lifetime
* @flags: KDBUS_NAME_* flags
* @conn: Connection owning the name
* @activator: Connection of the activator queuing incoming messages
* @queue: List of queued connections
* @conn_entry: Entry in connection
* @hentry: Entry in registry map
* @name: The well-known name
*/
struct kdbus_name_entry {
u64 name_id;
u64 flags;
struct kdbus_conn *conn;
struct kdbus_conn *activator;
struct list_head queue;
struct list_head conn_entry;
struct hlist_node hentry;
char name[];
};
bool kdbus_name_is_valid(const char *p, bool allow_wildcard);
struct kdbus_name_registry *kdbus_name_registry_new(void);
void kdbus_name_registry_free(struct kdbus_name_registry *reg);
struct kdbus_name_entry *
kdbus_name_lookup_unlocked(struct kdbus_name_registry *reg, const char *name);
int kdbus_name_acquire(struct kdbus_name_registry *reg,
struct kdbus_conn *conn, const char *name,
u64 flags, u64 *return_flags);
void kdbus_name_release_all(struct kdbus_name_registry *reg,
struct kdbus_conn *conn);
int kdbus_cmd_name_acquire(struct kdbus_conn *conn, void __user *argp);
int kdbus_cmd_name_release(struct kdbus_conn *conn, void __user *argp);
int kdbus_cmd_list(struct kdbus_conn *conn, void __user *argp);
#endif
|