summaryrefslogtreecommitdiffstats
path: root/src/core/arm/skyeye_common/vfp/asm_vfp.h
blob: 15b2394eb4b34647574a5b68dbba165587692561 (plain) (blame)
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
/*
 * arch/arm/include/asm/vfp.h
 *
 * VFP register definitions.
 * First, the standard VFP set.
 */

#pragma once

// ARM11 MPCore FPSID Information
// Note that these are used as values and not as flags.
enum : u32 {
    VFP_FPSID_IMPLMEN = 0x41, // Implementation code. Should be the same as cp15 0 c0 0
    VFP_FPSID_SW = 0,         // Software emulation bit value
    VFP_FPSID_SUBARCH = 0x1,  // Subarchitecture version number
    VFP_FPSID_PARTNUM = 0x20, // Part number
    VFP_FPSID_VARIANT = 0xB,  // Variant number
    VFP_FPSID_REVISION = 0x4  // Revision number
};

// FPEXC bits
enum : u32 {
    FPEXC_EX = (1U << 31U),
    FPEXC_EN = (1 << 30),
    FPEXC_DEX = (1 << 29),
    FPEXC_FP2V = (1 << 28),
    FPEXC_VV = (1 << 27),
    FPEXC_TFV = (1 << 26),
    FPEXC_LENGTH_BIT = (8),
    FPEXC_LENGTH_MASK = (7 << FPEXC_LENGTH_BIT),
    FPEXC_IDF = (1 << 7),
    FPEXC_IXF = (1 << 4),
    FPEXC_UFF = (1 << 3),
    FPEXC_OFF = (1 << 2),
    FPEXC_DZF = (1 << 1),
    FPEXC_IOF = (1 << 0),
    FPEXC_TRAP_MASK = (FPEXC_IDF | FPEXC_IXF | FPEXC_UFF | FPEXC_OFF | FPEXC_DZF | FPEXC_IOF)
};

// FPSCR Flags
enum : u32 {
    FPSCR_NFLAG = (1U << 31U), // Negative condition flag
    FPSCR_ZFLAG = (1 << 30),   // Zero condition flag
    FPSCR_CFLAG = (1 << 29),   // Carry condition flag
    FPSCR_VFLAG = (1 << 28),   // Overflow condition flag

    FPSCR_QC = (1 << 27),            // Cumulative saturation bit
    FPSCR_AHP = (1 << 26),           // Alternative half-precision control bit
    FPSCR_DEFAULT_NAN = (1 << 25),   // Default NaN mode control bit
    FPSCR_FLUSH_TO_ZERO = (1 << 24), // Flush-to-zero mode control bit
    FPSCR_RMODE_MASK = (3 << 22),    // Rounding Mode bit mask
    FPSCR_STRIDE_MASK = (3 << 20),   // Vector stride bit mask
    FPSCR_LENGTH_MASK = (7 << 16),   // Vector length bit mask

    FPSCR_IDE = (1 << 15), // Input Denormal exception trap enable.
    FPSCR_IXE = (1 << 12), // Inexact exception trap enable
    FPSCR_UFE = (1 << 11), // Undeflow exception trap enable
    FPSCR_OFE = (1 << 10), // Overflow exception trap enable
    FPSCR_DZE = (1 << 9),  // Division by Zero exception trap enable
    FPSCR_IOE = (1 << 8),  // Invalid Operation exception trap enable

    FPSCR_IDC = (1 << 7), // Input Denormal cumulative exception bit
    FPSCR_IXC = (1 << 4), // Inexact cumulative exception bit
    FPSCR_UFC = (1 << 3), // Undeflow cumulative exception bit
    FPSCR_OFC = (1 << 2), // Overflow cumulative exception bit
    FPSCR_DZC = (1 << 1), // Division by Zero cumulative exception bit
    FPSCR_IOC = (1 << 0), // Invalid Operation cumulative exception bit
};

// FPSCR bit offsets
enum : u32 {
    FPSCR_RMODE_BIT = 22,
    FPSCR_STRIDE_BIT = 20,
    FPSCR_LENGTH_BIT = 16,
};

// FPSCR rounding modes
enum : u32 {
    FPSCR_ROUND_NEAREST = (0 << 22),
    FPSCR_ROUND_PLUSINF = (1 << 22),
    FPSCR_ROUND_MINUSINF = (2 << 22),
    FPSCR_ROUND_TOZERO = (3 << 22)
};