// vim:set ft=cpp: -*- Mode: C++ -*- /** * \file * Unique_cap / Unique_del_cap */ /* * (c) 2017 Alexander Warg * * This file is part of TUD:OS and distributed under the terms of the * GNU General Public License 2. * Please see the COPYING-GPL-2 file for details. * * As a special exception, you may use this file as part of a free software * library without restriction. Specifically, if other files instantiate * templates or use macros or inline functions from this file, or you compile * this file and link it with other files to produce an executable, this * file does not by itself cause the resulting executable to be covered by * the GNU General Public License. This exception does not however * invalidate any other reasons why the executable file might be covered by * the GNU General Public License. */ #pragma once #include #include namespace L4Re { namespace Util { /** * Unique capability that implements automatic free and unmap of the * capability selector. * * \tparam T Type of the object the capability refers to. * * The ownership of the capability is managed in the same way as unique_ptr. * * Usage: * * { * L4Re::Util::Unique_cap * ds_cap = L4Re::Util::make_unique_cap(); * * // use the dataspace cap * L4Re::chksys(mem_alloc->alloc(L4_PAGESIZE, ds_cap.get())); * * ... * * // At the end of the scope ds_cap is unmapped and the capability * // selector is freed. * } */ template< typename T > using Unique_cap = L4::Detail::Unique_cap_impl>; /// \copydoc Unique_cap template< typename T > using unique_cap = L4::Detail::Unique_cap_impl>; /** * Allocate a capability slot and wrap it in an Unique_cap. * * \tparam T Type of the object the capability refers to. */ template< typename T > Unique_cap make_unique_cap() { return Unique_cap(cap_alloc.alloc()); } /** * Unique capability that implements automatic free and unmap+delete of the * capability selector. * * \tparam T Type of the object the capability refers to. * * The main difference to Unique_cap is that the unmap is done with the * deletion flag enabled and this leads to the deletion of the object * if the current task holds appropriate deletion rights. * * Usage: * * { * L4Re::Util::Unique_del_cap * ds_cap = make_unique_del_cap()); * * // use the dataspace cap * L4Re::chksys(mem_alloc->alloc(L4_PAGESIZE, ds_cap.get())); * * ... * * // At the end of the scope ds_cap is unmapped and the capability * // selector is freed. Because the deletion flag is set the data space * // shall also be deleted (even if there are other references to this * // data space). * } */ template< typename T > using Unique_del_cap = L4::Detail::Unique_cap_impl>; template< typename T > /// \copydoc Unique_del_cap using unique_del_cap = L4::Detail::Unique_cap_impl>; /** * Allocate a capability slot and wrap it in an Unique_del_cap. * * \tparam T Type of the object the capability refers to. */ template< typename T > Unique_del_cap make_unique_del_cap() { return Unique_del_cap(cap_alloc.alloc()); } }}