aboutsummaryrefslogtreecommitdiff
path: root/include/hw/core/resetcontainer.h
blob: 23db0c7a880619f2e644a1bc6aa706731fae54c7 (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
/*
 * Reset container
 *
 * Copyright (c) 2024 Linaro, Ltd
 *
 * This work is licensed under the terms of the GNU GPL, version 2 or later.
 * See the COPYING file in the top-level directory.
 */

#ifndef HW_RESETCONTAINER_H
#define HW_RESETCONTAINER_H

/*
 * The "reset container" is an object which implements the Resettable
 * interface. It contains a list of arbitrary other objects which also
 * implement Resettable. Resetting the reset container resets all the
 * objects in it.
 */

#include "qom/object.h"

#define TYPE_RESETTABLE_CONTAINER "resettable-container"
OBJECT_DECLARE_TYPE(ResettableContainer, ResettableContainerClass, RESETTABLE_CONTAINER)

/**
 * resettable_container_add: Add a resettable object to the container
 * @rc: container
 * @obj: object to add to the container
 *
 * Add @obj to the ResettableContainer @rc. @obj must implement the
 * Resettable interface.
 *
 * When @rc is reset, it will reset every object that has been added
 * to it, in the order they were added.
 */
void resettable_container_add(ResettableContainer *rc, Object *obj);

/**
 * resettable_container_remove: Remove an object from the container
 * @rc: container
 * @obj: object to remove from the container
 *
 * Remove @obj from the ResettableContainer @rc. @obj must have been
 * previously added to this container.
 */
void resettable_container_remove(ResettableContainer *rc, Object *obj);

#endif