| /* |
| * 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 |