Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/src/hotspot/cpu/s390/bytes_s390.hpp
40930 views
1
/*
2
* Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved.
3
* Copyright (c) 2016, 2018 SAP SE. All rights reserved.
4
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5
*
6
* This code is free software; you can redistribute it and/or modify it
7
* under the terms of the GNU General Public License version 2 only, as
8
* published by the Free Software Foundation.
9
*
10
* This code is distributed in the hope that it will be useful, but WITHOUT
11
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
13
* version 2 for more details (a copy is included in the LICENSE file that
14
* accompanied this code).
15
*
16
* You should have received a copy of the GNU General Public License version
17
* 2 along with this work; if not, write to the Free Software Foundation,
18
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
19
*
20
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
21
* or visit www.oracle.com if you need additional information or have any
22
* questions.
23
*
24
*/
25
26
#ifndef CPU_S390_BYTES_S390_HPP
27
#define CPU_S390_BYTES_S390_HPP
28
29
#include "memory/allocation.hpp"
30
31
class Bytes: AllStatic {
32
public:
33
// Efficient reading and writing of unaligned unsigned data in
34
// platform-specific byte ordering.
35
36
// Use regular load and store for unaligned access.
37
//
38
// On z/Architecture, unaligned loads and stores are supported when using the
39
// "traditional" load (LH, L/LY, LG) and store (STH, ST/STY, STG) instructions.
40
// The penalty for unaligned access is just very few (two or three) ticks,
41
// plus another few (two or three) ticks if the access crosses a cache line boundary.
42
//
43
// In short, it makes no sense on z/Architecture to piecemeal get or put unaligned data.
44
45
static inline u2 get_native_u2(address p) { return *(u2*)p; }
46
static inline u4 get_native_u4(address p) { return *(u4*)p; }
47
static inline u8 get_native_u8(address p) { return *(u8*)p; }
48
49
static inline void put_native_u2(address p, u2 x) { *(u2*)p = x; }
50
static inline void put_native_u4(address p, u4 x) { *(u4*)p = x; }
51
static inline void put_native_u8(address p, u8 x) { *(u8*)p = x; }
52
53
// The following header contains the implementations of swap_u2, swap_u4, and swap_u8.
54
#include OS_CPU_HEADER(bytes)
55
56
// Efficient reading and writing of unaligned unsigned data in Java byte ordering (i.e. big-endian ordering)
57
static inline u2 get_Java_u2(address p) { return get_native_u2(p); }
58
static inline u4 get_Java_u4(address p) { return get_native_u4(p); }
59
static inline u8 get_Java_u8(address p) { return get_native_u8(p); }
60
61
static inline void put_Java_u2(address p, u2 x) { put_native_u2(p, x); }
62
static inline void put_Java_u4(address p, u4 x) { put_native_u4(p, x); }
63
static inline void put_Java_u8(address p, u8 x) { put_native_u8(p, x); }
64
};
65
66
#endif // CPU_S390_BYTES_S390_HPP
67
68