1 | /* SPDX-License-Identifier: BSD-2-Clause */ |
---|
2 | |
---|
3 | /** |
---|
4 | * @file |
---|
5 | * |
---|
6 | * @ingroup RTEMSScoreHeap |
---|
7 | * |
---|
8 | * @brief This source file contains the implementation of |
---|
9 | * _Heap_Get_free_information(). |
---|
10 | */ |
---|
11 | |
---|
12 | /* |
---|
13 | * COPYRIGHT (c) 1989-2004. |
---|
14 | * On-Line Applications Research Corporation (OAR). |
---|
15 | * |
---|
16 | * Redistribution and use in source and binary forms, with or without |
---|
17 | * modification, are permitted provided that the following conditions |
---|
18 | * are met: |
---|
19 | * 1. Redistributions of source code must retain the above copyright |
---|
20 | * notice, this list of conditions and the following disclaimer. |
---|
21 | * 2. Redistributions in binary form must reproduce the above copyright |
---|
22 | * notice, this list of conditions and the following disclaimer in the |
---|
23 | * documentation and/or other materials provided with the distribution. |
---|
24 | * |
---|
25 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
---|
26 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
---|
27 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
---|
28 | * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE |
---|
29 | * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
---|
30 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
---|
31 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
---|
32 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
---|
33 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
---|
34 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
---|
35 | * POSSIBILITY OF SUCH DAMAGE. |
---|
36 | */ |
---|
37 | |
---|
38 | #ifdef HAVE_CONFIG_H |
---|
39 | #include "config.h" |
---|
40 | #endif |
---|
41 | |
---|
42 | #include <rtems/score/heapimpl.h> |
---|
43 | |
---|
44 | void _Heap_Get_free_information( |
---|
45 | Heap_Control *the_heap, |
---|
46 | Heap_Information *info |
---|
47 | ) |
---|
48 | { |
---|
49 | Heap_Block *the_block; |
---|
50 | Heap_Block *const tail = _Heap_Free_list_tail(the_heap); |
---|
51 | |
---|
52 | info->number = 0; |
---|
53 | info->largest = 0; |
---|
54 | info->total = 0; |
---|
55 | |
---|
56 | for(the_block = _Heap_Free_list_first(the_heap); |
---|
57 | the_block != tail; |
---|
58 | the_block = the_block->next) |
---|
59 | { |
---|
60 | uint32_t const the_size = _Heap_Block_size(the_block); |
---|
61 | |
---|
62 | /* As we always coalesce free blocks, prev block must have been used. */ |
---|
63 | _HAssert(_Heap_Is_prev_used(the_block)); |
---|
64 | |
---|
65 | info->number++; |
---|
66 | info->total += the_size; |
---|
67 | if ( info->largest < the_size ) |
---|
68 | info->largest = the_size; |
---|
69 | } |
---|
70 | } |
---|