forked from Imagelibrary/rtems
99 lines
2.9 KiB
Ada
99 lines
2.9 KiB
Ada
-- SPDX-License-Identifier: BSD-2-Clause
|
|
|
|
--
|
|
-- RTEMS / Body
|
|
--
|
|
-- DESCRIPTION:
|
|
--
|
|
-- This package provides the interface to the RTEMS API.
|
|
--
|
|
--
|
|
-- DEPENDENCIES:
|
|
--
|
|
--
|
|
--
|
|
-- COPYRIGHT (c) 1997-2011.
|
|
-- On-Line Applications Research Corporation (OAR).
|
|
--
|
|
-- Redistribution and use in source and binary forms, with or without
|
|
-- modification, are permitted provided that the following conditions
|
|
-- are met:
|
|
-- 1. Redistributions of source code must retain the above copyright
|
|
-- notice, this list of conditions and the following disclaimer.
|
|
-- 2. Redistributions in binary form must reproduce the above copyright
|
|
-- notice, this list of conditions and the following disclaimer in the
|
|
-- documentation and/or other materials provided with the distribution.
|
|
--
|
|
-- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
-- AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
-- IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
-- ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
-- LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
-- CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
-- SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
-- INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
-- CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
-- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
-- POSSIBILITY OF SUCH DAMAGE.
|
|
--
|
|
|
|
package body RTEMS.Extension is
|
|
|
|
--
|
|
-- Extension Manager
|
|
--
|
|
|
|
procedure Create
|
|
(Name : in RTEMS.Name;
|
|
Table : in RTEMS.Extensions_Table_Pointer;
|
|
ID : out RTEMS.ID;
|
|
Result : out RTEMS.Status_Codes)
|
|
is
|
|
function Create_Base
|
|
(Name : RTEMS.Name;
|
|
Table : RTEMS.Extensions_Table_Pointer;
|
|
ID : access RTEMS.ID)
|
|
return RTEMS.Status_Codes;
|
|
pragma Import (C, Create_Base, "rtems_extension_create");
|
|
ID_Base : aliased RTEMS.ID;
|
|
begin
|
|
|
|
Result := Create_Base (Name, Table, ID_Base'Access);
|
|
ID := ID_Base;
|
|
|
|
end Create;
|
|
|
|
procedure Ident
|
|
(Name : in RTEMS.Name;
|
|
ID : out RTEMS.ID;
|
|
Result : out RTEMS.Status_Codes)
|
|
is
|
|
function Ident_Base
|
|
(Name : RTEMS.Name;
|
|
ID : access RTEMS.ID)
|
|
return RTEMS.Status_Codes;
|
|
pragma Import (C, Ident_Base, "rtems_extension_ident");
|
|
ID_Base : aliased RTEMS.ID;
|
|
begin
|
|
|
|
Result := Ident_Base (Name, ID_Base'Access);
|
|
ID := ID_Base;
|
|
|
|
end Ident;
|
|
|
|
procedure Delete
|
|
(ID : in RTEMS.ID;
|
|
Result : out RTEMS.Status_Codes)
|
|
is
|
|
function Delete_Base
|
|
(ID : RTEMS.ID)
|
|
return RTEMS.Status_Codes;
|
|
pragma Import (C, Delete_Base, "rtems_extension_delete");
|
|
begin
|
|
|
|
Result := Delete_Base (ID);
|
|
|
|
end Delete;
|
|
|
|
end RTEMS.Extension;
|