dynarmic/externals/xbyak
Merry 8f890d327a externals: Update xbyak to 6.61
Merge commit '5b6e3d8b54e428fceedd907cf5c0f52ca98eb003'
2022-07-31 17:50:57 +01:00
..
.github externals: Update xbyak to v6.06 2022-06-05 13:31:49 +01:00
cmake externals: Update xbyak to v6.06 2022-06-05 13:31:49 +01:00
doc externals: Update xbyak to 6.61 2022-07-31 17:50:57 +01:00
gen externals: Update xbyak to 6.60.1 2022-06-16 06:53:34 +01:00
sample externals: Update xbyak to 6.61 2022-07-31 17:50:57 +01:00
test externals: Update xbyak to 6.61 2022-07-31 17:50:57 +01:00
xbyak externals: Update xbyak to 6.61 2022-07-31 17:50:57 +01:00
.gitignore externals: Update xbyak 2021-03-27 21:08:22 +00:00
CMakeLists.txt externals: Update xbyak to 6.61 2022-07-31 17:50:57 +01:00
COPYRIGHT externals: Update xbyak to v6.06 2022-06-05 13:31:49 +01:00
Makefile
meson.build externals: Update xbyak to 6.61 2022-07-31 17:50:57 +01:00
readme.md externals: Update xbyak to 6.61 2022-07-31 17:50:57 +01:00
readme.txt externals: Update xbyak to 6.61 2022-07-31 17:50:57 +01:00
xbyak.sln

Xbyak 6.61 Badge Build

A C++ JIT assembler for x86 (IA32), x64 (AMD64, x86-64)

Menu

Abstract

Xbyak is a C++ header library that enables dynamically to assemble x86(IA32), x64(AMD64, x86-64) mnemonic.

The pronunciation of Xbyak is kəi-bja-k. It is named from a Japanese word 開闢, which means the beginning of the world.

Feature

  • header file only
  • Intel/MASM like syntax
  • fully support AVX-512

Note: Use and_(), or_(), ... instead of and(), or(). If you want to use them, then specify -fno-operator-names option to gcc/clang.

News

  • add movdiri, movdir64b, clwb, cldemote
  • WAITPKG instructions (tpause, umonitor, umwait) are supported.
  • MmapAllocator supports memfd with user-defined strings. see sample/memfd.cpp
  • strictly check address offset disp32 in a signed 32-bit integer. e.g., ptr[(void*)0xffffffff] causes an error.
    • define XBYAK_OLD_DISP_CHECK if you need an old check, but the option will be remoevd.
  • add jmp(mem, T_FAR), call(mem, T_FAR) retf() for far absolute indirect jump.
  • vnni instructions such as vpdpbusd supports vex encoding.
  • (break backward compatibility) push(byte, imm) (resp. push(word, imm)) forces to cast imm to 8(resp. 16) bit.
  • (Windows) #include <winsock2.h> has been removed from xbyak.h, so add it explicitly if you need it.
  • support exception-less mode see. Exception-less mode
  • XBYAK_USE_MMAP_ALLOCATOR will be defined on Linux/macOS unless XBYAK_DONT_USE_MMAP_ALLOCATOR is defined.

Supported OS

  • Windows (Xp, Vista, 7, 10, 11) (32 / 64 bit)
  • Linux (32 / 64 bit)
  • macOS (Intel CPU)

Supported Compilers

Almost C++03 or later compilers for x86/x64 such as Visual Studio, g++, clang++, Intel C++ compiler and g++ on mingw/cygwin.

License

BSD-3-Clause License

Author

光成滋生Mitsunari Shigeo

GitHub|Website (Japanese)|herumi@nifty.com

Sponsors welcome

GitHub Sponsor