added spl.h
changed SpinLock.hpp to use spl.h
This commit is contained in:
@ -23,8 +23,9 @@ bin_PROGRAMS = \
|
||||
sio01 \
|
||||
sio02 \
|
||||
sio03 \
|
||||
spl01 \
|
||||
task01 \
|
||||
thr01
|
||||
thr01
|
||||
|
||||
AM_LDFLAGS = -L../../lib/si -L../../lib/cmn
|
||||
AM_CFLAGS = $(PTHREAD_CFLAGS)
|
||||
@ -53,6 +54,7 @@ rwl01_SOURCES = rwl01.c
|
||||
sio01_SOURCES = sio01.c
|
||||
sio02_SOURCES = sio02.c
|
||||
sio03_SOURCES = sio03.c
|
||||
spl01_SOURCES = spl01.c
|
||||
task01_SOURCES = task01.c
|
||||
thr01_SOURCES = thr01.c
|
||||
|
||||
|
@ -92,8 +92,8 @@ bin_PROGRAMS = aio01$(EXEEXT) dir01$(EXEEXT) fio01$(EXEEXT) \
|
||||
fio02$(EXEEXT) fs01$(EXEEXT) fs02$(EXEEXT) fs03$(EXEEXT) \
|
||||
glob01$(EXEEXT) log01$(EXEEXT) nwad01$(EXEEXT) nwif01$(EXEEXT) \
|
||||
nwif02$(EXEEXT) pio01$(EXEEXT) rwl01$(EXEEXT) sio01$(EXEEXT) \
|
||||
sio02$(EXEEXT) sio03$(EXEEXT) task01$(EXEEXT) thr01$(EXEEXT) \
|
||||
$(am__EXEEXT_1)
|
||||
sio02$(EXEEXT) sio03$(EXEEXT) spl01$(EXEEXT) task01$(EXEEXT) \
|
||||
thr01$(EXEEXT) $(am__EXEEXT_1)
|
||||
@WCHAR_TRUE@@WIN32_TRUE@am__append_1 = $(UNICOWS_LIBS)
|
||||
@ENABLE_CXX_TRUE@am__append_2 = thr02 spl02
|
||||
subdir = samples/si
|
||||
@ -190,6 +190,10 @@ am_sio03_OBJECTS = sio03.$(OBJEXT)
|
||||
sio03_OBJECTS = $(am_sio03_OBJECTS)
|
||||
sio03_LDADD = $(LDADD)
|
||||
sio03_DEPENDENCIES = $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_2)
|
||||
am_spl01_OBJECTS = spl01.$(OBJEXT)
|
||||
spl01_OBJECTS = $(am_spl01_OBJECTS)
|
||||
spl01_LDADD = $(LDADD)
|
||||
spl01_DEPENDENCIES = $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_2)
|
||||
am__spl02_SOURCES_DIST = spl02.cpp
|
||||
@ENABLE_CXX_TRUE@am_spl02_OBJECTS = spl02.$(OBJEXT)
|
||||
spl02_OBJECTS = $(am_spl02_OBJECTS)
|
||||
@ -266,15 +270,17 @@ SOURCES = $(aio01_SOURCES) $(dir01_SOURCES) $(fio01_SOURCES) \
|
||||
$(fs03_SOURCES) $(glob01_SOURCES) $(log01_SOURCES) \
|
||||
$(nwad01_SOURCES) $(nwif01_SOURCES) $(nwif02_SOURCES) \
|
||||
$(pio01_SOURCES) $(rwl01_SOURCES) $(sio01_SOURCES) \
|
||||
$(sio02_SOURCES) $(sio03_SOURCES) $(spl02_SOURCES) \
|
||||
$(task01_SOURCES) $(thr01_SOURCES) $(thr02_SOURCES)
|
||||
$(sio02_SOURCES) $(sio03_SOURCES) $(spl01_SOURCES) \
|
||||
$(spl02_SOURCES) $(task01_SOURCES) $(thr01_SOURCES) \
|
||||
$(thr02_SOURCES)
|
||||
DIST_SOURCES = $(aio01_SOURCES) $(dir01_SOURCES) $(fio01_SOURCES) \
|
||||
$(fio02_SOURCES) $(fs01_SOURCES) $(fs02_SOURCES) \
|
||||
$(fs03_SOURCES) $(glob01_SOURCES) $(log01_SOURCES) \
|
||||
$(nwad01_SOURCES) $(nwif01_SOURCES) $(nwif02_SOURCES) \
|
||||
$(pio01_SOURCES) $(rwl01_SOURCES) $(sio01_SOURCES) \
|
||||
$(sio02_SOURCES) $(sio03_SOURCES) $(am__spl02_SOURCES_DIST) \
|
||||
$(task01_SOURCES) $(thr01_SOURCES) $(am__thr02_SOURCES_DIST)
|
||||
$(sio02_SOURCES) $(sio03_SOURCES) $(spl01_SOURCES) \
|
||||
$(am__spl02_SOURCES_DIST) $(task01_SOURCES) $(thr01_SOURCES) \
|
||||
$(am__thr02_SOURCES_DIST)
|
||||
am__can_run_installinfo = \
|
||||
case $$AM_UPDATE_INFO_DIR in \
|
||||
n|no|NO) false;; \
|
||||
@ -507,6 +513,7 @@ rwl01_SOURCES = rwl01.c
|
||||
sio01_SOURCES = sio01.c
|
||||
sio02_SOURCES = sio02.c
|
||||
sio03_SOURCES = sio03.c
|
||||
spl01_SOURCES = spl01.c
|
||||
task01_SOURCES = task01.c
|
||||
thr01_SOURCES = thr01.c
|
||||
@ENABLE_CXX_TRUE@CXXLIB = -lqsesixx -lqsecmnxx
|
||||
@ -665,6 +672,10 @@ sio03$(EXEEXT): $(sio03_OBJECTS) $(sio03_DEPENDENCIES) $(EXTRA_sio03_DEPENDENCIE
|
||||
@rm -f sio03$(EXEEXT)
|
||||
$(AM_V_CCLD)$(LINK) $(sio03_OBJECTS) $(sio03_LDADD) $(LIBS)
|
||||
|
||||
spl01$(EXEEXT): $(spl01_OBJECTS) $(spl01_DEPENDENCIES) $(EXTRA_spl01_DEPENDENCIES)
|
||||
@rm -f spl01$(EXEEXT)
|
||||
$(AM_V_CCLD)$(LINK) $(spl01_OBJECTS) $(spl01_LDADD) $(LIBS)
|
||||
|
||||
spl02$(EXEEXT): $(spl02_OBJECTS) $(spl02_DEPENDENCIES) $(EXTRA_spl02_DEPENDENCIES)
|
||||
@rm -f spl02$(EXEEXT)
|
||||
$(AM_V_CXXLD)$(CXXLINK) $(spl02_OBJECTS) $(spl02_LDADD) $(LIBS)
|
||||
@ -704,6 +715,7 @@ distclean-compile:
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sio01.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sio02.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sio03.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/spl01.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/spl02.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/task01.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/thr01.Po@am__quote@
|
||||
|
174
qse/samples/si/spl01.c
Normal file
174
qse/samples/si/spl01.c
Normal file
@ -0,0 +1,174 @@
|
||||
#include <qse/si/spl.h>
|
||||
#include <qse/si/thr.h>
|
||||
#include <qse/si/sio.h>
|
||||
#include <qse/cmn/mem.h>
|
||||
|
||||
|
||||
#include <locale.h>
|
||||
#if defined(_WIN32)
|
||||
# include <windows.h>
|
||||
#endif
|
||||
|
||||
#include <unistd.h>
|
||||
#include <signal.h>
|
||||
#include <string.h>
|
||||
|
||||
static int g_stopreq = 0;
|
||||
|
||||
struct thr_xtn_t
|
||||
{
|
||||
int stopreq;
|
||||
qse_char_t name[32];
|
||||
qse_spl_t* spl;
|
||||
};
|
||||
typedef struct thr_xtn_t thr_xtn_t;
|
||||
|
||||
static int thr_func (qse_thr_t* thr, void* ctx)
|
||||
{
|
||||
int i = 0;
|
||||
thr_xtn_t* xtn = qse_thr_getxtn(thr);
|
||||
|
||||
while (!xtn->stopreq)
|
||||
{
|
||||
qse_spl_lock (xtn->spl);
|
||||
qse_printf (QSE_T("%s: [% 16d] [% 16d] [% 16d]\n"), xtn->name, i, i, i);
|
||||
qse_spl_unlock (xtn->spl);
|
||||
i++;
|
||||
//sleep (1);
|
||||
}
|
||||
|
||||
return i;
|
||||
}
|
||||
|
||||
static int test1 (void)
|
||||
{
|
||||
qse_thr_t* thr1, * thr2;
|
||||
qse_spl_t spl;
|
||||
thr_xtn_t* xtn1, * xtn2;
|
||||
|
||||
qse_spl_init (&spl);
|
||||
|
||||
thr1 = qse_thr_open (QSE_MMGR_GETDFL(), QSE_SIZEOF(thr_xtn_t));
|
||||
if (!thr1)
|
||||
{
|
||||
qse_printf (QSE_T("cannot open thread1\n"));
|
||||
return -1;
|
||||
}
|
||||
|
||||
thr2 = qse_thr_open (QSE_MMGR_GETDFL(), QSE_SIZEOF(thr_xtn_t));
|
||||
if (!thr2)
|
||||
{
|
||||
qse_printf (QSE_T("cannot open thread2\n"));
|
||||
return -1;
|
||||
}
|
||||
|
||||
xtn1 = qse_thr_getxtn(thr1);
|
||||
xtn2 = qse_thr_getxtn(thr2);
|
||||
|
||||
qse_strcpy (xtn1->name, QSE_T("Thr-X"));
|
||||
qse_strcpy (xtn2->name, QSE_T("Thr-Y"));
|
||||
xtn1->spl = &spl;
|
||||
xtn2->spl = &spl;
|
||||
|
||||
qse_thr_setstacksize (thr1, 64000);
|
||||
qse_thr_setstacksize (thr2, 64000);
|
||||
|
||||
if (qse_thr_start(thr1, thr_func, QSE_NULL, QSE_THR_SIGNALS_BLOCKED) <= -1)
|
||||
{
|
||||
qse_printf (QSE_T("cannot start thread1\n"));
|
||||
qse_thr_close (thr1 );
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (qse_thr_start(thr2, thr_func, QSE_NULL, QSE_THR_SIGNALS_BLOCKED) <= -1)
|
||||
{
|
||||
qse_printf (QSE_T("cannot start thread1\n"));
|
||||
qse_thr_close (thr1 );
|
||||
return -1;
|
||||
}
|
||||
|
||||
while (!g_stopreq)
|
||||
{
|
||||
if (qse_thr_getstate(thr1) == QSE_THR_TERMINATED &&
|
||||
qse_thr_getstate(thr2) == QSE_THR_TERMINATED) break;
|
||||
sleep (1);
|
||||
}
|
||||
|
||||
if (g_stopreq)
|
||||
{
|
||||
xtn1->stopreq = 1;
|
||||
xtn2->stopreq = 1;
|
||||
}
|
||||
|
||||
qse_thr_join (thr1);
|
||||
qse_thr_join (thr2);
|
||||
|
||||
qse_printf (QSE_T("thread1 ended with retcode %d\n"), qse_thr_getretcode(thr1));
|
||||
qse_printf (QSE_T("thread2 ended with retcode %d\n"), qse_thr_getretcode(thr2));
|
||||
qse_thr_close (thr1);
|
||||
qse_thr_close (thr2);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void handle_sigint (int sig, siginfo_t* siginfo, void* ctx)
|
||||
{
|
||||
g_stopreq = 1;
|
||||
}
|
||||
|
||||
static void set_signal (int sig, void(*handler)(int, siginfo_t*, void*))
|
||||
{
|
||||
struct sigaction sa;
|
||||
|
||||
memset (&sa, 0, sizeof(sa));
|
||||
/*sa.sa_handler = handler;*/
|
||||
sa.sa_flags = SA_SIGINFO;
|
||||
sa.sa_sigaction = handler;
|
||||
sigemptyset (&sa.sa_mask);
|
||||
|
||||
sigaction (sig, &sa, NULL);
|
||||
}
|
||||
|
||||
static void set_signal_to_default (int sig)
|
||||
{
|
||||
struct sigaction sa;
|
||||
|
||||
memset (&sa, 0, sizeof(sa));
|
||||
sa.sa_handler = SIG_DFL;
|
||||
sa.sa_flags = 0;
|
||||
sigemptyset (&sa.sa_mask);
|
||||
|
||||
sigaction (sig, &sa, NULL);
|
||||
}
|
||||
|
||||
int main ()
|
||||
{
|
||||
#if defined(_WIN32)
|
||||
char locale[100];
|
||||
UINT codepage = GetConsoleOutputCP();
|
||||
if (codepage == CP_UTF8)
|
||||
{
|
||||
/*SetConsoleOUtputCP (CP_UTF8);*/
|
||||
qse_setdflcmgrbyid (QSE_CMGR_UTF8);
|
||||
}
|
||||
else
|
||||
{
|
||||
sprintf (locale, ".%u", (unsigned int)codepage);
|
||||
setlocale (LC_ALL, locale);
|
||||
/*qse_setdflcmgrbyid (QSE_CMGR_SLMB);*/
|
||||
}
|
||||
#else
|
||||
setlocale (LC_ALL, "");
|
||||
/*qse_setdflcmgrbyid (QSE_CMGR_SLMB);*/
|
||||
#endif
|
||||
|
||||
set_signal (SIGINT, handle_sigint);
|
||||
|
||||
qse_open_stdsios ();
|
||||
test1();
|
||||
qse_close_stdsios ();
|
||||
|
||||
set_signal_to_default (SIGINT);
|
||||
|
||||
return 0;
|
||||
}
|
Reference in New Issue
Block a user