stack_pointer.h revision 1.1 1 1.1 pho /* $NetBSD: stack_pointer.h,v 1.1 2024/04/22 07:24:22 pho Exp $ */
2 1.1 pho
3 1.1 pho /*
4 1.1 pho * Copyright (c) 2024 The NetBSD Foundation, Inc.
5 1.1 pho * All rights reserved.
6 1.1 pho *
7 1.1 pho * Redistribution and use in source and binary forms, with or without
8 1.1 pho * modification, are permitted provided that the following conditions
9 1.1 pho * are met:
10 1.1 pho * 1. Redistributions of source code must retain the above copyright
11 1.1 pho * notice, this list of conditions and the following disclaimer.
12 1.1 pho * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 pho * notice, this list of conditions and the following disclaimer in the
14 1.1 pho * documentation and/or other materials provided with the distribution.
15 1.1 pho *
16 1.1 pho * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
17 1.1 pho * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
18 1.1 pho * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 1.1 pho * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
20 1.1 pho * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 1.1 pho * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 1.1 pho * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23 1.1 pho * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24 1.1 pho * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25 1.1 pho * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26 1.1 pho * POSSIBILITY OF SUCH DAMAGE.
27 1.1 pho */
28 1.1 pho
29 1.1 pho #include <sys/stdbool.h>
30 1.1 pho #include <sys/stdint.h>
31 1.1 pho
32 1.1 pho #define LOAD_SP(var) \
33 1.1 pho do { \
34 1.1 pho register void* tmp __asm__("x0"); \
35 1.1 pho __asm__( \
36 1.1 pho "mov %0, sp" \
37 1.1 pho : "=r"(tmp) \
38 1.1 pho ); \
39 1.1 pho (var) = tmp; \
40 1.1 pho } while (0)
41 1.1 pho
42 1.1 pho #define MISALIGN_SP \
43 1.1 pho __asm__ volatile ( \
44 1.1 pho "sub sp, sp, #8" \
45 1.1 pho )
46 1.1 pho
47 1.1 pho #define FIX_SP \
48 1.1 pho __asm__ volatile ( \
49 1.1 pho "add sp, sp, #8" \
50 1.1 pho )
51 1.1 pho
52 1.1 pho static inline bool
53 1.1 pho is_sp_aligned(uintptr_t sp)
54 1.1 pho {
55 1.1 pho return sp % 16 == 0;
56 1.1 pho }
57