Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Dill upstream #3420

Merged
merged 3 commits into from
Dec 22, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 6 additions & 6 deletions thirdparty/dill/dill/.github/workflows/build-and-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -83,14 +83,14 @@ jobs:
matrix:
buildtype: [ release, debug ]
jobname: [
#windows2019-vs2019-clang,
#windows2022-vs2022-msvc,
windows2019-vs2019-clang,
windows2022-vs2022-msvc,
macos-clang ]
include:
#- jobname: windows2019-vs2019-clang
# vm: windows-2019
#- jobname: windows2022-vs2022-msvc
# vm: windows-2022
- jobname: windows2019-vs2019-clang
vm: windows-2019
- jobname: windows2022-vs2022-msvc
vm: windows-2022
- jobname: macos-clang
vm: macos-latest

Expand Down
2 changes: 2 additions & 0 deletions thirdparty/dill/dill/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,7 @@ set(SRC_list
virtual.c
dill.c
vm.c
x86_64_disassembler.c
)

set(TARGET_DEP_INC)
Expand Down Expand Up @@ -153,6 +154,7 @@ if(CMAKE_SYSTEM_NAME MATCHES "Darwin|Linux")
set(USE_MMAP_CODE_SEG 1)
elseif(CMAKE_SYSTEM_NAME MATCHES "Windows")
set(USE_VIRTUAL_PROTECT 1)
set(USE_WINDOWS_CALLS 1)
endif()

include(TestBigEndian)
Expand Down
4 changes: 3 additions & 1 deletion thirdparty/dill/dill/cmake/FindLibFFI.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,8 @@ if(NOT (PC_LIBFFI_FOUND STREQUAL "IGNORE"))
set(_PF_TYPE _STATIC)
endif()
set(LIBFFI_INCLUDE_DIRS ${PC_LIBFFI${_PC_TYPE}_INCLUDE_DIRS})
set(LIBFFI_LIBRARIES ${PC_LIBFFI${_PC_TYPE}_LDFLAGS})
set(LIBFFI_LIBRARIES ${PC_LIBFFI${_PC_TYPE}_LIBRARIES})
set(LIBFFI_LIBRARY_DIRS ${PC_LIBFFI${_PC_TYPE}_LIBRARY_DIRS})
set(LIBFFI_DEFINITIONS ${PC_LIBFFI${PC_TYPE}_CFLAGS_OTHER})
endif()
endif()
Expand All @@ -57,6 +58,7 @@ if(LIBFFI_FOUND)
if(LIBFFI_LIBRARIES)
set_target_properties(libffi::libffi PROPERTIES
INTERFACE_LINK_LIBRARIES "${LIBFFI_LIBRARIES}"
INTERFACE_LINK_DIRECTORIES "${LIBFFI_LIBRARY_DIRS}"
)
endif()
endif()
Expand Down
7 changes: 5 additions & 2 deletions thirdparty/dill/dill/config.h.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -143,12 +143,15 @@
*/
#cmakedefine USE_MEMBAR

/* Define this is mmap should be used instead of malloc() for code memory */
/* Define this if mmap should be used instead of malloc() for code memory */
#cmakedefine USE_MMAP_CODE_SEG

/* Define this is VirtualProtect should be used to change memory protections */
/* Define this if VirtualProtect should be used to change memory protections */
#cmakedefine USE_VIRTUAL_PROTECT

/* Define this if windows calling convention should be used */
#cmakedefine USE_WINDOWS_CALLS

/* Define if byteorder is bigendian */
#cmakedefine WORDS_BIGENDIAN

Expand Down
9 changes: 5 additions & 4 deletions thirdparty/dill/dill/dill_util.c
Original file line number Diff line number Diff line change
Expand Up @@ -1532,10 +1532,11 @@ dill_dump(dill_stream s)
printf("No code to dump\n");
return;
}
if ((s->j != s->p->virtual.mach_jump) && native_missing) {
printf("No native disassembler available\n");
return;
}
/* if ((s->j != s->p->virtual.mach_jump) && native_missing) { */
/* printf("No native disassembler available\n"); */
/* return; */
/* } */
(void) native_missing;
if (s->j->init_disassembly(s, &info) == 0) {
printf("No native disassembler available\n");
} else {
Expand Down
44 changes: 43 additions & 1 deletion thirdparty/dill/dill/tests/t1.c
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,15 @@
#include "dill.h"
#include <stdlib.h>

#ifdef TESTING
unsigned int x86_64_disassemble(unsigned char *bytes, unsigned int max, int offset, char *output);

int test (int val)
{
return val;
}
#endif

int main(int argc, char **argv)
{
dill_stream s = dill_create_raw_stream();
Expand All @@ -29,6 +38,39 @@ int main(int argc, char **argv)
exit(1);
}
}

#ifdef TESTING
{
dill_stream s = dill_create_raw_stream();
dill_reg param0;
dill_exec_handle h;
int result;
int (*proc)(int);
int s2i = 0xdeadbeef;
dill_start_proc(s, "param1_i", DILL_I, "%i");
param0 = dill_param_reg(s, 0);
dill_reti(s, param0);
h = dill_finalize(s);
proc = (int (*)(int)) dill_get_fp(h);
result = proc(s2i);
dill_dump(s);
if (result != s2i) {
printf("test for 1 arguments of type \"i\" failed, expected %x, got %x\n",
s2i, result);
dill_dump(s);
printf("\n*************\n\n");
}
}
{
printf("\nDisassembly of Test *************\n\n");
unsigned char *tmp = (unsigned char*) &test;
int i = 0;
for (i = 0; i < 40; ) {
char out[128];
int ret = x86_64_disassemble(tmp + i, sizeof(out), 0, out);
printf("%s\n", out);
i += ret;
}
}
#endif
return 0;
}
20 changes: 16 additions & 4 deletions thirdparty/dill/dill/x86_64.c
Original file line number Diff line number Diff line change
Expand Up @@ -710,6 +710,8 @@ x86_64_save_restore_op(dill_stream s, int save_restore, int type, int reg)
}

/*
* This is linux convention. Windows is different.
*
* register use preserved across function calls
* %rax temporary register; with variable arguments
* passes information about the
Expand Down Expand Up @@ -758,7 +760,11 @@ Register Offset
%xmm15 288

*/
#ifndef USE_WINDOWS_CALLS
static int arg_regs[] = {RDI, RSI, RDX, RCX, R8, R9};
#else
static int arg_regs[] = {RCX, RDX, R8, R9};
#endif

static void
save_required_regs(dill_stream s, int force)
Expand Down Expand Up @@ -2250,7 +2256,7 @@ static void internal_push(dill_stream s, int type, int immediate,
}
}
if ((arg.type != DILL_D) && (arg.type != DILL_F)) {
if (smi->int_arg_count < 6) {
if (smi->int_arg_count < sizeof(arg_regs) / sizeof(arg_regs[0])) {
arg.is_register = 1;
arg.in_reg = arg.out_reg = arg_regs[smi->int_arg_count];
smi->int_arg_count++;
Expand Down Expand Up @@ -2604,7 +2610,7 @@ x86_64_flush(void *base, void *limit)
asm volatile ("clflush (%0)" : /* */ : "r" (ptr));
#endif
#else
_mm_clflush(ptr);
_mm_clflush((const void *) ptr);
#endif
ptr = (char *)ptr + 8;
}
Expand Down Expand Up @@ -2854,8 +2860,14 @@ x86_64_count_insn(dill_stream s, int start, int end)
return end - start;
}
extern int
x86_64_init_disassembly_info(dill_stream s, void * ptr){return 0;}
extern int x86_64_print_insn(dill_stream s, void *info_ptr, void *insn){return 0;}
x86_64_init_disassembly_info(dill_stream s, void * ptr){return 1;}
unsigned int x86_64_disassemble(unsigned char *bytes, unsigned int max, int offset, char *output);
extern int x86_64_print_insn(dill_stream s, void *info_ptr, void *insn){
char out[128] = "";
int ret = x86_64_disassemble(insn, sizeof(out), 0, out);
printf("%s", out);
return ret;
}
#endif

extern void
Expand Down
Loading