Categories:
Audio (13)
Biotech (29)
Bytecode (36)
Database (77)
Framework (7)
Game (7)
General (507)
Graphics (53)
I/O (35)
IDE (2)
JAR Tools (101)
JavaBeans (21)
JDBC (121)
JDK (426)
JSP (20)
Logging (108)
Mail (58)
Messaging (8)
Network (84)
PDF (97)
Report (7)
Scripting (84)
Security (32)
Server (121)
Servlet (26)
SOAP (24)
Testing (54)
Web (15)
XML (309)
Collections:
Other Resources:
JDK 17 jdk.incubator.foreign.jmod - JDK Incubator Foreign
JDK 17 jdk.incubator.foreign.jmod is the JMOD file for JDK 17 HTTP Server module.
JDK 17 Incubator Foreign module compiled class files are stored in \fyicenter\jdk-17.0.5\jmods\jdk.incubator.foreign.jmod.
JDK 17 Incubator Foreign module compiled class files are also linked and stored in the \fyicenter\jdk-17.0.5\lib\modules JImage file.
JDK 17 Incubator Foreign module source code files are stored in \fyicenter\jdk-17.0.5\lib\src.zip\jdk.incubator.foreign.
You can click and view the content of each source code file in the list below.
✍: FYIcenter
⏎ jdk/internal/foreign/abi/aarch64/linux/LinuxAArch64VaList.java
/* * Copyright (c) 2020, 2021, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2020, 2021, Arm Limited. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ package jdk.internal.foreign.abi.aarch64.linux; import jdk.incubator.foreign.*; import jdk.internal.foreign.Utils; import jdk.internal.foreign.abi.SharedUtils; import jdk.internal.foreign.abi.aarch64.*; import jdk.internal.misc.Unsafe; import java.lang.invoke.VarHandle; import java.lang.ref.Cleaner; import java.nio.ByteOrder; import java.util.ArrayList; import java.util.List; import java.util.Objects; import static jdk.internal.foreign.PlatformLayouts.AArch64; import static jdk.incubator.foreign.CLinker.VaList; import static jdk.incubator.foreign.MemoryLayout.PathElement.groupElement; import static jdk.internal.foreign.abi.SharedUtils.SimpleVaArg; import static jdk.internal.foreign.abi.SharedUtils.THROWING_ALLOCATOR; import static jdk.internal.foreign.abi.SharedUtils.checkCompatibleType; import static jdk.internal.foreign.abi.SharedUtils.vhPrimitiveOrAddress; import static jdk.internal.foreign.abi.aarch64.CallArranger.MAX_REGISTER_ARGUMENTS; /** * Standard va_list implementation as defined by AAPCS document and used on * Linux. Variadic parameters may be passed in registers or on the stack. */ public non-sealed class LinuxAArch64VaList implements VaList { private static final Unsafe U = Unsafe.getUnsafe(); static final Class<?> CARRIER = MemoryAddress.class; // See AAPCS Appendix B "Variable Argument Lists" for definition of // va_list on AArch64. // // typedef struct __va_list { // void *__stack; // next stack param // void *__gr_top; // end of GP arg reg save area // void *__vr_top; // end of FP/SIMD arg reg save area // int __gr_offs; // offset from __gr_top to next GP register arg // int __vr_offs; // offset from __vr_top to next FP/SIMD register arg // } va_list; static final GroupLayout LAYOUT = MemoryLayout.structLayout( AArch64.C_POINTER.withName("__stack"), AArch64.C_POINTER.withName("__gr_top"), AArch64.C_POINTER.withName("__vr_top"), AArch64.C_INT.withName("__gr_offs"), AArch64.C_INT.withName("__vr_offs") ).withName("__va_list"); private static final MemoryLayout GP_REG = MemoryLayout.valueLayout(64, ByteOrder.nativeOrder()); private static final MemoryLayout FP_REG = MemoryLayout.valueLayout(128, ByteOrder.nativeOrder()); private static final MemoryLayout LAYOUT_GP_REGS = MemoryLayout.sequenceLayout(MAX_REGISTER_ARGUMENTS, GP_REG); private static final MemoryLayout LAYOUT_FP_REGS = MemoryLayout.sequenceLayout(MAX_REGISTER_ARGUMENTS, FP_REG); private static final int GP_SLOT_SIZE = (int) GP_REG.byteSize(); private static final int FP_SLOT_SIZE = (int) FP_REG.byteSize(); private static final int MAX_GP_OFFSET = (int) LAYOUT_GP_REGS.byteSize(); private static final int MAX_FP_OFFSET = (int) LAYOUT_FP_REGS.byteSize(); private static final VarHandle VH_stack = MemoryHandles.asAddressVarHandle(LAYOUT.varHandle(long.class, groupElement("__stack"))); private static final VarHandle VH_gr_top = MemoryHandles.asAddressVarHandle(LAYOUT.varHandle(long.class, groupElement("__gr_top"))); private static final VarHandle VH_vr_top = MemoryHandles.asAddressVarHandle(LAYOUT.varHandle(long.class, groupElement("__vr_top"))); private static final VarHandle VH_gr_offs = LAYOUT.varHandle(int.class, groupElement("__gr_offs")); private static final VarHandle VH_vr_offs = LAYOUT.varHandle(int.class, groupElement("__vr_offs")); private static final Cleaner cleaner = Cleaner.create(); private static final VaList EMPTY = new SharedUtils.EmptyVaList(emptyListAddress()); private final MemorySegment segment; private final MemorySegment gpRegsArea; private final MemorySegment fpRegsArea; private LinuxAArch64VaList(MemorySegment segment, MemorySegment gpRegsArea, MemorySegment fpRegsArea) { this.segment = segment; this.gpRegsArea = gpRegsArea; this.fpRegsArea = fpRegsArea; } private static LinuxAArch64VaList readFromSegment(MemorySegment segment) { MemorySegment gpRegsArea = grTop(segment).addOffset(-MAX_GP_OFFSET).asSegment( MAX_GP_OFFSET, segment.scope()); MemorySegment fpRegsArea = vrTop(segment).addOffset(-MAX_FP_OFFSET).asSegment( MAX_FP_OFFSET, segment.scope()); return new LinuxAArch64VaList(segment, gpRegsArea, fpRegsArea); } private static MemoryAddress emptyListAddress() { long ptr = U.allocateMemory(LAYOUT.byteSize()); MemorySegment ms = MemoryAddress.ofLong(ptr).asSegment( LAYOUT.byteSize(), () -> U.freeMemory(ptr), ResourceScope.newSharedScope()); cleaner.register(LinuxAArch64VaList.class, () -> ms.scope().close()); VH_stack.set(ms, MemoryAddress.NULL); VH_gr_top.set(ms, MemoryAddress.NULL); VH_vr_top.set(ms, MemoryAddress.NULL); VH_gr_offs.set(ms, 0); VH_vr_offs.set(ms, 0); return ms.address(); } public static VaList empty() { return EMPTY; } private MemoryAddress grTop() { return grTop(segment); } private static MemoryAddress grTop(MemorySegment segment) { return (MemoryAddress) VH_gr_top.get(segment); } private MemoryAddress vrTop() { return vrTop(segment); } private static MemoryAddress vrTop(MemorySegment segment) { return (MemoryAddress) VH_vr_top.get(segment); } private int grOffs() { final int offs = (int) VH_gr_offs.get(segment); assert offs <= 0; return offs; } private int vrOffs() { final int offs = (int) VH_vr_offs.get(segment); assert offs <= 0; return offs; } private MemoryAddress stackPtr() { return (MemoryAddress) VH_stack.get(segment); } private void stackPtr(MemoryAddress ptr) { VH_stack.set(segment, ptr); } private void consumeGPSlots(int num) { final int old = (int) VH_gr_offs.get(segment); VH_gr_offs.set(segment, old + num * GP_SLOT_SIZE); } private void consumeFPSlots(int num) { final int old = (int) VH_vr_offs.get(segment); VH_vr_offs.set(segment, old + num * FP_SLOT_SIZE); } private long currentGPOffset() { // Offset from start of GP register segment. __gr_top points to the top // (highest address) of the GP registers area. __gr_offs is the negative // offset of next saved register from the top. return gpRegsArea.byteSize() + grOffs(); } private long currentFPOffset() { // Offset from start of FP register segment. __vr_top points to the top // (highest address) of the FP registers area. __vr_offs is the negative // offset of next saved register from the top. return fpRegsArea.byteSize() + vrOffs(); } private void preAlignStack(MemoryLayout layout) { if (layout.byteAlignment() > 8) { stackPtr(Utils.alignUp(stackPtr(), 16)); } } private void postAlignStack(MemoryLayout layout) { stackPtr(Utils.alignUp(stackPtr().addOffset(layout.byteSize()), 8)); } @Override public int vargAsInt(MemoryLayout layout) { return (int) read(int.class, layout); } @Override public long vargAsLong(MemoryLayout layout) { return (long) read(long.class, layout); } @Override public double vargAsDouble(MemoryLayout layout) { return (double) read(double.class, layout); } @Override public MemoryAddress vargAsAddress(MemoryLayout layout) { return (MemoryAddress) read(MemoryAddress.class, layout); } @Override public MemorySegment vargAsSegment(MemoryLayout layout, SegmentAllocator allocator) { Objects.requireNonNull(allocator); return (MemorySegment) read(MemorySegment.class, layout, allocator); } @Override public MemorySegment vargAsSegment(MemoryLayout layout, ResourceScope scope) { return vargAsSegment(layout, SegmentAllocator.ofScope(scope)); } private Object read(Class<?> carrier, MemoryLayout layout) { return read(carrier, layout, THROWING_ALLOCATOR); } private Object read(Class<?> carrier, MemoryLayout layout, SegmentAllocator allocator) { Objects.requireNonNull(layout); checkCompatibleType(carrier, layout, LinuxAArch64Linker.ADDRESS_SIZE); TypeClass typeClass = TypeClass.classifyLayout(layout); if (isRegOverflow(currentGPOffset(), currentFPOffset(), typeClass, layout)) { preAlignStack(layout); return switch (typeClass) { case STRUCT_REGISTER, STRUCT_HFA, STRUCT_REFERENCE -> { MemorySegment slice = stackPtr().asSegment(layout.byteSize(), scope()); MemorySegment seg = allocator.allocate(layout); seg.copyFrom(slice); postAlignStack(layout); yield seg; } case POINTER, INTEGER, FLOAT -> { VarHandle reader = vhPrimitiveOrAddress(carrier, layout); MemorySegment slice = stackPtr().asSegment(layout.byteSize(), scope()); Object res = reader.get(slice); postAlignStack(layout); yield res; } }; } else { return switch (typeClass) { case STRUCT_REGISTER -> { // Struct is passed packed in integer registers. MemorySegment value = allocator.allocate(layout); long offset = 0; while (offset < layout.byteSize()) { final long copy = Math.min(layout.byteSize() - offset, 8); MemorySegment slice = value.asSlice(offset, copy); slice.copyFrom(gpRegsArea.asSlice(currentGPOffset(), copy)); consumeGPSlots(1); offset += copy; } yield value; } case STRUCT_HFA -> { // Struct is passed with each element in a separate floating // point register. MemorySegment value = allocator.allocate(layout); GroupLayout group = (GroupLayout)layout; long offset = 0; for (MemoryLayout elem : group.memberLayouts()) { assert elem.byteSize() <= 8; final long copy = elem.byteSize(); MemorySegment slice = value.asSlice(offset, copy); slice.copyFrom(fpRegsArea.asSlice(currentFPOffset(), copy)); consumeFPSlots(1); offset += copy; } yield value; } case STRUCT_REFERENCE -> { // Struct is passed indirectly via a pointer in an integer register. VarHandle ptrReader = SharedUtils.vhPrimitiveOrAddress(MemoryAddress.class, AArch64.C_POINTER); MemoryAddress ptr = (MemoryAddress) ptrReader.get( gpRegsArea.asSlice(currentGPOffset())); consumeGPSlots(1); MemorySegment slice = ptr.asSegment(layout.byteSize(), scope()); MemorySegment seg = allocator.allocate(layout); seg.copyFrom(slice); yield seg; } case POINTER, INTEGER -> { VarHandle reader = SharedUtils.vhPrimitiveOrAddress(carrier, layout); Object res = reader.get(gpRegsArea.asSlice(currentGPOffset())); consumeGPSlots(1); yield res; } case FLOAT -> { VarHandle reader = layout.varHandle(carrier); Object res = reader.get(fpRegsArea.asSlice(currentFPOffset())); consumeFPSlots(1); yield res; } }; } } @Override public void skip(MemoryLayout... layouts) { Objects.requireNonNull(layouts); for (MemoryLayout layout : layouts) { Objects.requireNonNull(layout); TypeClass typeClass = TypeClass.classifyLayout(layout); if (isRegOverflow(currentGPOffset(), currentFPOffset(), typeClass, layout)) { preAlignStack(layout); postAlignStack(layout); } else if (typeClass == TypeClass.FLOAT || typeClass == TypeClass.STRUCT_HFA) { consumeFPSlots(numSlots(layout)); } else if (typeClass == TypeClass.STRUCT_REFERENCE) { consumeGPSlots(1); } else { consumeGPSlots(numSlots(layout)); } } } static LinuxAArch64VaList.Builder builder(ResourceScope scope) { return new LinuxAArch64VaList.Builder(scope); } public static VaList ofAddress(MemoryAddress ma, ResourceScope scope) { return readFromSegment(ma.asSegment(LAYOUT.byteSize(), scope)); } @Override public ResourceScope scope() { return segment.scope(); } @Override public VaList copy() { MemorySegment copy = MemorySegment.allocateNative(LAYOUT, segment.scope()); copy.copyFrom(segment); return new LinuxAArch64VaList(copy, gpRegsArea, fpRegsArea); } @Override public MemoryAddress address() { return segment.address(); } private static int numSlots(MemoryLayout layout) { return (int) Utils.alignUp(layout.byteSize(), 8) / 8; } private static boolean isRegOverflow(long currentGPOffset, long currentFPOffset, TypeClass typeClass, MemoryLayout layout) { if (typeClass == TypeClass.FLOAT || typeClass == TypeClass.STRUCT_HFA) { return currentFPOffset > MAX_FP_OFFSET - numSlots(layout) * FP_SLOT_SIZE; } else if (typeClass == TypeClass.STRUCT_REFERENCE) { return currentGPOffset > MAX_GP_OFFSET - GP_SLOT_SIZE; } else { return currentGPOffset > MAX_GP_OFFSET - numSlots(layout) * GP_SLOT_SIZE; } } @Override public String toString() { return "LinuxAArch64VaList{" + "__stack=" + stackPtr() + ", __gr_top=" + grTop() + ", __vr_top=" + vrTop() + ", __gr_offs=" + grOffs() + ", __vr_offs=" + vrOffs() + '}'; } public static non-sealed class Builder implements VaList.Builder { private final ResourceScope scope; private final MemorySegment gpRegs; private final MemorySegment fpRegs; private long currentGPOffset = 0; private long currentFPOffset = 0; private final List<SimpleVaArg> stackArgs = new ArrayList<>(); Builder(ResourceScope scope) { this.scope = scope; this.gpRegs = MemorySegment.allocateNative(LAYOUT_GP_REGS, scope); this.fpRegs = MemorySegment.allocateNative(LAYOUT_FP_REGS, scope); } @Override public Builder vargFromInt(ValueLayout layout, int value) { return arg(int.class, layout, value); } @Override public Builder vargFromLong(ValueLayout layout, long value) { return arg(long.class, layout, value); } @Override public Builder vargFromDouble(ValueLayout layout, double value) { return arg(double.class, layout, value); } @Override public Builder vargFromAddress(ValueLayout layout, Addressable value) { return arg(MemoryAddress.class, layout, value.address()); } @Override public Builder vargFromSegment(GroupLayout layout, MemorySegment value) { return arg(MemorySegment.class, layout, value); } private Builder arg(Class<?> carrier, MemoryLayout layout, Object value) { Objects.requireNonNull(layout); Objects.requireNonNull(value); checkCompatibleType(carrier, layout, LinuxAArch64Linker.ADDRESS_SIZE); TypeClass typeClass = TypeClass.classifyLayout(layout); if (isRegOverflow(currentGPOffset, currentFPOffset, typeClass, layout)) { stackArgs.add(new SimpleVaArg(carrier, layout, value)); } else { switch (typeClass) { case STRUCT_REGISTER -> { // Struct is passed packed in integer registers. MemorySegment valueSegment = (MemorySegment) value; long offset = 0; while (offset < layout.byteSize()) { final long copy = Math.min(layout.byteSize() - offset, 8); MemorySegment slice = valueSegment.asSlice(offset, copy); gpRegs.asSlice(currentGPOffset, copy).copyFrom(slice); currentGPOffset += GP_SLOT_SIZE; offset += copy; } } case STRUCT_HFA -> { // Struct is passed with each element in a separate floating // point register. MemorySegment valueSegment = (MemorySegment) value; GroupLayout group = (GroupLayout)layout; long offset = 0; for (MemoryLayout elem : group.memberLayouts()) { assert elem.byteSize() <= 8; final long copy = elem.byteSize(); MemorySegment slice = valueSegment.asSlice(offset, copy); fpRegs.asSlice(currentFPOffset, copy).copyFrom(slice); currentFPOffset += FP_SLOT_SIZE; offset += copy; } } case STRUCT_REFERENCE -> { // Struct is passed indirectly via a pointer in an integer register. MemorySegment valueSegment = (MemorySegment) value; VarHandle writer = SharedUtils.vhPrimitiveOrAddress(MemoryAddress.class, AArch64.C_POINTER); writer.set(gpRegs.asSlice(currentGPOffset), valueSegment.address()); currentGPOffset += GP_SLOT_SIZE; } case POINTER, INTEGER -> { VarHandle writer = SharedUtils.vhPrimitiveOrAddress(carrier, layout); writer.set(gpRegs.asSlice(currentGPOffset), value); currentGPOffset += GP_SLOT_SIZE; } case FLOAT -> { VarHandle writer = layout.varHandle(carrier); writer.set(fpRegs.asSlice(currentFPOffset), value); currentFPOffset += FP_SLOT_SIZE; } } } return this; } private boolean isEmpty() { return currentGPOffset == 0 && currentFPOffset == 0 && stackArgs.isEmpty(); } public VaList build() { if (isEmpty()) { return EMPTY; } SegmentAllocator allocator = SegmentAllocator.arenaAllocator(scope); MemorySegment vaListSegment = allocator.allocate(LAYOUT); MemoryAddress stackArgsPtr = MemoryAddress.NULL; if (!stackArgs.isEmpty()) { long stackArgsSize = stackArgs.stream() .reduce(0L, (acc, e) -> acc + Utils.alignUp(e.layout.byteSize(), 8), Long::sum); MemorySegment stackArgsSegment = allocator.allocate(stackArgsSize, 16); stackArgsPtr = stackArgsSegment.address(); for (SimpleVaArg arg : stackArgs) { final long alignedSize = Utils.alignUp(arg.layout.byteSize(), 8); stackArgsSegment = Utils.alignUp(stackArgsSegment, alignedSize); VarHandle writer = arg.varHandle(); writer.set(stackArgsSegment, arg.value); stackArgsSegment = stackArgsSegment.asSlice(alignedSize); } } VH_gr_top.set(vaListSegment, gpRegs.asSlice(gpRegs.byteSize()).address()); VH_vr_top.set(vaListSegment, fpRegs.asSlice(fpRegs.byteSize()).address()); VH_stack.set(vaListSegment, stackArgsPtr); VH_gr_offs.set(vaListSegment, -MAX_GP_OFFSET); VH_vr_offs.set(vaListSegment, -MAX_FP_OFFSET); assert gpRegs.scope().ownerThread() == vaListSegment.scope().ownerThread(); assert fpRegs.scope().ownerThread() == vaListSegment.scope().ownerThread(); return new LinuxAArch64VaList(vaListSegment, gpRegs, fpRegs); } } }
⏎ jdk/internal/foreign/abi/aarch64/linux/LinuxAArch64VaList.java
Or download all of them as a single archive file:
File name: jdk.incubator.foreign-17.0.5-src.zip File size: 168767 bytes Release date: 2022-09-13 Download
⇒ JDK 17 jdk.incubator.vector.jmod - JDK Incubator Vector
2023-10-04, 3909👍, 0💬
Popular Posts:
How to show the XML parsing flow with sax\DocumentTracer.java provided in the Apache Xerces package?...
xml-commons External Source Code Files are provided in the source package file, xml-commons-external...
XML Serializer, Release 2.7.1, allows you to write out XML, HTML etc. as a stream of characters from...
maven-compat-3.8.6.jar is the JAR file for Apache Maven 3.8.6 Compact module. The JAR file name may ...
Apache BCEL Source Code Files are inside the Apache BCEL source package file like bcel-6.5.0-src.zip...