mirror of
https://github.com/ptitSeb/box64.git
synced 2025-05-09 00:21:32 +08:00

* Improve the ReserveHigMemory helper function * [BOX32] Added some wrapping infrastructure * [BOX32] More wrapped 32bits lib infrastructure * [BOX32] Added callback and tls 32bits handling * [BOX32] Added more 32bits, around wrappers and elfs * [BOX32] Added the 32bits version of myalign * [BOX32] More wrapped libs and 32bits fixes and imrpovments * [BOX32] Added some 32bits tests * [BOX32] Try to enable some Box32 build and test on the CI * [BOX32] Disable Box32 testing on CI platform that use qemu * [BOX32] Another attempt to disable Box32 testing on CI platform that use qemu * [BOX32] Small fix for another attempt to disable Box32 testing on CI platform that use qemu * [BOX32] Yet another fix for another attempt to disable Box32 testing on CI platform that use qemu * [BOX32] Fixed a typo in CI script * [BOX32] Better scratch alighnment and enabled more tests * [BOX32] Added (partial) wrapped 32bits librt * [BOX32] Added mention of Box32 in README * [BOX32] Added phtread handling, and numerous fixes to 32bits handling. [ARM64_DYNAREC] Fixed access to segment with negative offset * [BOX32] Added system libs and cpp testing, plus some more fixes * [BOX32] Fix previous commit * [BOX32] Better stack adjustment for 32bits processes * [BOX32] Added getenv wrapped 32bits function and friends * [BOX32] Don't look for box86 for a Box32 build * [BOX32] Don't do 32bits cppThreads test for now on CI * [BOX32] Enabled a few more 32bits tests * [BOX32] For ld_lib_path for both CppThreads tests * [BOX32] [ANDROID] Some Fixes for Android Build * [BOX32] Still need to disable cppThread_32bits test on CI for some reason * [BOX32] [ANDROID] Don't show PreInit Array Warning (#1751) * [BOX32] [ANDROID] One More Fix for Android Build That I forgotten to … (#1752) * [BOX32] [ANDROID] One More Fix for Android Build That I forgotten to push before * [BOX32] [ANDROID] Try to Create __libc_init * [BOX32] [ANDROID] Try to disable NEEDED_LIBS for now (libdl is not wrapped) * [BOX32] Updated generated files * [BOX32] Added 32bits context functions * [BOX32] Added 32bits signal handling * [BOX32] Added some missing 32bits elfloader functions * [BOX32] Fix build on x86_64 machine * [BOX32] Better fix for x86_64 build * [BOX32] Actually added missing libs, and re-enabled cppThreads_32bits test * [BOX32] Added wrapped 32bits libdl * [BOX32] Try to re-enabled Box32 test on CI for ARM64 builds * [BOX32] fine-tuning Box32 test on CI for ARM64 builds * [BOX32] More fine-tuning to Box32 test on CI for ARM64 builds * [BOX32] Enabled Box32 test on CI for LA64 and RV64 builds too * [BOX32] re-Disabled Box32 test on CI for LA64 and RV64 builds, not working for now * [BOX32] Temporarily disabled cppThreads_32bits test on CI --------- Co-authored-by: KreitinnSoftware <pablopro5051@gmail.com> Co-authored-by: KreitinnSoftware <80591934+KreitinnSoftware@users.noreply.github.com>
132 lines
3.5 KiB
C
132 lines
3.5 KiB
C
#define _MULTI_THREADED
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <pthread.h>
|
|
#include <unistd.h>
|
|
|
|
void foo(void); /* Functions that use the TLS data */
|
|
void bar(void);
|
|
|
|
#define checkResults(string, val) { \
|
|
if (val) { \
|
|
printf("Failed with %d at %s", val, string); \
|
|
exit(1); \
|
|
} \
|
|
}
|
|
|
|
/*
|
|
Use the keyword provided by pthread.h to delcare the following variable
|
|
is thread specific, i.e. it is only visible to a specific thread,
|
|
not shared/common to all thread.
|
|
These variables are stored in thread local storage (TLS) area.
|
|
*/
|
|
__thread int TLS_data1 = 10;
|
|
__thread int TLS_data2 = 20;
|
|
__thread char TLS_data3[10];
|
|
|
|
// Sync, because it's needed apparently...
|
|
static pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
|
|
static pthread_mutex_t* mutex_ptr = &mutex;
|
|
static pthread_cond_t thread_state_cond = PTHREAD_COND_INITIALIZER;
|
|
static pthread_cond_t* thread_state_cond_ptr = &thread_state_cond;
|
|
static int status = 0;
|
|
|
|
#define NUMTHREADS 2
|
|
pthread_t thread[NUMTHREADS];
|
|
|
|
typedef struct {
|
|
int data1;
|
|
int data2;
|
|
} threadparm_t;
|
|
|
|
void *thread_run(void *parm)
|
|
{
|
|
int rc;
|
|
threadparm_t *gData;
|
|
|
|
pthread_mutex_lock(mutex_ptr);
|
|
if (pthread_self()==thread[0]) {
|
|
printf("Thread 1: Entered (%d/%d)\n", TLS_data1, TLS_data2);
|
|
fflush(stdout);
|
|
} else {
|
|
while (!status) pthread_cond_wait(thread_state_cond_ptr, mutex_ptr);
|
|
printf("Thread 2: Entered (%d/%d)\n", TLS_data1, TLS_data2);
|
|
fflush(stdout);
|
|
status = 0;
|
|
pthread_mutex_unlock(mutex_ptr);
|
|
pthread_cond_broadcast(thread_state_cond_ptr);
|
|
}
|
|
|
|
gData = (threadparm_t *)parm;
|
|
|
|
/* Assign the value from global variable to thread specific variable*/
|
|
TLS_data1 = gData->data1;
|
|
TLS_data2 = gData->data2;
|
|
strcpy(TLS_data3, "---");
|
|
TLS_data3[1] = (pthread_self()==thread[0])?'1':'2';
|
|
|
|
foo();
|
|
return NULL;
|
|
}
|
|
|
|
void foo() {
|
|
if (pthread_self()==thread[0]) {
|
|
printf("Thread 1: foo(), TLS data=%d %d \"%s\"\n", TLS_data1, TLS_data2, TLS_data3);
|
|
fflush(stdout);
|
|
status = 1;
|
|
pthread_cond_broadcast(thread_state_cond_ptr);
|
|
while (status) pthread_cond_wait(thread_state_cond_ptr, mutex_ptr);
|
|
pthread_mutex_unlock(mutex_ptr);
|
|
} else {
|
|
printf("Thread 2: foo(), TLS data=%d %d \"%s\"\n", TLS_data1, TLS_data2, TLS_data3);
|
|
fflush(stdout);
|
|
}
|
|
while(!thread[1])
|
|
usleep(300);
|
|
if(pthread_self()==thread[0])
|
|
pthread_join(thread[1], NULL);
|
|
bar();
|
|
}
|
|
|
|
void bar() {
|
|
printf("Thread %d: bar(), TLS data=%d %d \"%s\"\n",
|
|
(pthread_self()==thread[0])?1:2, TLS_data1, TLS_data2, TLS_data3);
|
|
fflush(stdout);
|
|
return;
|
|
}
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
int rc=0;
|
|
int i;
|
|
threadparm_t gData[NUMTHREADS];
|
|
|
|
printf("Create/start %d threads\n", NUMTHREADS);
|
|
fflush(stdout);
|
|
for (i=0; i < NUMTHREADS; i++) {
|
|
/* Create per-thread TLS data and pass it to the thread */
|
|
gData[i].data1 = i;
|
|
gData[i].data2 = (i+1)*2;
|
|
rc = pthread_create(&thread[i], NULL, thread_run, &gData[i]);
|
|
checkResults("pthread_create()\n", rc);
|
|
}
|
|
|
|
//printf("Wait for all threads to complete, and release their resources\n");
|
|
for (i=0; i < NUMTHREADS; i++) {
|
|
rc = pthread_join(thread[i], NULL);
|
|
//checkResults("pthread_join()\n", rc);
|
|
}
|
|
|
|
thread_state_cond_ptr = NULL;
|
|
i = pthread_cond_destroy(&thread_state_cond);
|
|
checkResults("destroying cond\n", i);
|
|
mutex_ptr = NULL;
|
|
i = pthread_mutex_destroy(&mutex);
|
|
checkResults("destroying mutex\n", i);
|
|
|
|
printf("Main completed\n");
|
|
fflush(stdout);
|
|
return 0;
|
|
}
|