summaryrefslogtreecommitdiff
path: root/include/shared_mem.h
blob: 482d3a6decd5a34dcf46a77fe350d80fe21f1853 (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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
/* Copyright 2011 The ChromiumOS Authors
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

/*
 * Shared memory interface for Chrome EC.
 *
 * This is intended to supply a relatively large block of memory for use by a
 * task for a relatively short amount of time.  For example, verified boot may
 * need a buffer to hold signature data during a verification operation.  It is
 * NOT intended for allocating long-term buffers; those should in general be
 * static variables allocated at compile-time.  It is NOT a full-featured
 * replacement for malloc() / free().
 */

#ifndef __CROS_EC_SHARED_MEM_H
#define __CROS_EC_SHARED_MEM_H

#include "common.h"

#include <stddef.h>

/**
 * Returns the maximum amount of shared memory which can be acquired, in
 * bytes.
 */
int shared_mem_size(void);

#define SHARED_MEM_CHECK_SIZE(size) \
	BUILD_ASSERT((size) <= CONFIG_SHAREDMEM_MINIMUM_SIZE)

/*
 * Acquires a shared memory area of the requested size in bytes.
 *
 * Doing a sysjump between images will corrupt and/or erase shared memory as
 * jump tags are added and .bss is reinitialized. Due to the way jump tags are
 * added to the end of RAM, shared memory must not be allocated, accessed, or
 * freed after the start of a sysjump (for example, in HOOK_SYSJUMP).
 *
 * @param size		Number of bytes requested
 * @param dest_ptr	If successful, set on return to the start of the
 *			granted memory buffer.
 *
 * @return EC_SUCCESS if successful, EC_ERROR_BUSY if buffer in use, or
 * other non-zero error code.
 */
int shared_mem_acquire(int size, char **dest_ptr);

#define SHARED_MEM_ACQUIRE_CHECK(size, dest_ptr)        \
	({                                              \
		SHARED_MEM_CHECK_SIZE(size);            \
		shared_mem_acquire((size), (dest_ptr)); \
	})

/**
 * Releases a shared memory area previously allocated via shared_mem_acquire().
 */
void shared_mem_release(void *ptr);

/*
 * This structure is allocated at the base of the free memory chunk and every
 * allocated buffer.
 */
struct shm_buffer {
	struct shm_buffer *next_buffer;
	struct shm_buffer *prev_buffer;
	size_t buffer_size;
};

#ifdef TEST_SHMALLOC

/*
 * When in test mode, all possible paths in the allocation/free functions set
 * unique bits in an integer bitmap.
 *
 * The test function generates random allocation and free requests and
 * monitors the bitmap until all bits have been set, which indicates that all
 * possible paths have been executed.
 */

#define MAX_MASK_BIT 24
#define ALL_PATHS_MASK ((1 << (MAX_MASK_BIT + 1)) - 1)
void set_map_bit(uint32_t mask);
extern struct shm_buffer *free_buf_chain;
extern struct shm_buffer *allocced_buf_chain;
#endif

#endif /* __CROS_EC_SHARED_MEM_H */