Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
A
abc
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
abc
Commits
34d59b0b
Commit
34d59b0b
authored
Feb 27, 2011
by
Baruch Sterin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fixes to pyabc kill mechanism
parent
02081dba
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
42 additions
and
68 deletions
+42
-68
scripts/reachx_cmd.py
+16
-6
src/misc/util/utilSignal.c
+0
-0
src/misc/util/utilSignal.h
+1
-8
src/python/module.make
+17
-0
src/python/pyabc.i
+0
-0
src/python/pyabc_split.py
+8
-54
No files found.
scripts/reachx_cmd.py
View file @
34d59b0b
...
@@ -12,24 +12,36 @@ from contextlib import contextmanager, nested
...
@@ -12,24 +12,36 @@ from contextlib import contextmanager, nested
import
pyabc
import
pyabc
def
wait_with_timeout
(
p
,
timeout
):
def
popen_and_wait_with_timeout
(
timeout
,
cmd
,
*
args
,
**
kwargs
):
""" Wait for a subprocess.Popen object to terminate, or until timeout (in seconds) expires. """
""" Wait for a subprocess.Popen object to terminate, or until timeout (in seconds) expires. """
p
=
None
t
=
None
try
:
p
=
subprocess
.
Popen
(
cmd
,
*
args
,
**
kwargs
)
if
timeout
<=
0
:
if
timeout
<=
0
:
timeout
=
None
timeout
=
None
t
=
threading
.
Thread
(
target
=
lambda
:
p
.
wait
())
t
=
threading
.
Thread
(
target
=
lambda
:
p
.
communicate
())
t
.
start
()
t
.
start
()
t
.
join
(
timeout
)
t
.
join
(
timeout
)
if
t
.
is_alive
():
finally
:
if
p
is
not
None
and
p
.
poll
()
is
None
:
p
.
kill
()
p
.
kill
()
if
t
is
not
None
and
t
.
is_alive
():
t
.
join
()
t
.
join
()
if
p
is
not
None
:
return
p
.
returncode
return
p
.
returncode
return
-
1
@contextmanager
@contextmanager
def
replace_sys_argv
(
argv
):
def
replace_sys_argv
(
argv
):
if
'argv'
in
sys
.
__dict__
:
if
'argv'
in
sys
.
__dict__
:
...
@@ -77,9 +89,7 @@ def run_reachx_cmd(effort, timeout):
...
@@ -77,9 +89,7 @@ def run_reachx_cmd(effort, timeout):
cmd
=
[
"jabc"
,
"-c"
,
" ; "
.
join
(
cmdline
)]
cmd
=
[
"jabc"
,
"-c"
,
" ; "
.
join
(
cmdline
)]
p
=
subprocess
.
Popen
(
cmd
,
shell
=
False
,
stdout
=
sys
.
stdout
,
stderr
=
sys
.
stderr
)
rc
=
popen_and_wait_with_timeout
(
timeout
,
cmd
,
shell
=
False
,
stdout
=
sys
.
stdout
,
stderr
=
sys
.
stderr
)
rc
=
wait_with_timeout
(
p
,
timeout
)
if
rc
!=
0
:
if
rc
!=
0
:
# jabc failed or stopped. Write a status file to update the status to unknown
# jabc failed or stopped. Write a status file to update the status to unknown
...
...
src/misc/util/utilSignal.c
View file @
34d59b0b
This diff is collapsed.
Click to expand it.
src/misc/util/utilSignal.h
View file @
34d59b0b
...
@@ -44,14 +44,7 @@ ABC_NAMESPACE_HEADER_START
...
@@ -44,14 +44,7 @@ ABC_NAMESPACE_HEADER_START
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
/*=== utilSignal.c ==========================================================*/
/*=== utilSignal.c ==========================================================*/
extern
void
Util_SignalCleanup
();
extern
void
Util_SignalStartHandler
();
extern
void
Util_SignalResetHandler
();
extern
void
Util_SignalStopHandler
();
extern
void
Util_SignalBlockSignals
();
extern
void
Util_SignalUnblockSignals
();
extern
void
Util_SignalAddChildPid
(
int
pid
);
extern
void
Util_SignalRemoveChildPid
(
int
pid
);
extern
int
Util_SignalTmpFile
(
const
char
*
prefix
,
const
char
*
suffix
,
char
**
out_name
);
extern
int
Util_SignalTmpFile
(
const
char
*
prefix
,
const
char
*
suffix
,
char
**
out_name
);
extern
void
Util_SignalTmpFileRemove
(
const
char
*
fname
,
int
fLeave
);
extern
void
Util_SignalTmpFileRemove
(
const
char
*
fname
,
int
fLeave
);
extern
int
Util_SignalSystem
(
const
char
*
cmd
);
extern
int
Util_SignalSystem
(
const
char
*
cmd
);
...
...
src/python/module.make
View file @
34d59b0b
...
@@ -61,4 +61,21 @@ pyabc.tgz : $(PROG) $(ABC_PYTHON_SRC:_wrap.c=.py) $(ABC_PYTHON_FILES_PREFIX)/abc
...
@@ -61,4 +61,21 @@ pyabc.tgz : $(PROG) $(ABC_PYTHON_SRC:_wrap.c=.py) $(ABC_PYTHON_FILES_PREFIX)/abc
--out
=
$@
\
--out
=
$@
\
$(ABC_PYTHON_OPTIONS)
$(ABC_PYTHON_OPTIONS)
PYABC_INSTALL_TARGET
?=
$(
shell
date +%Y-%m-%d_%H-%M.%N_
${
USER
}
)
PYABC_INSTALL_TARGET
:=
$(PYABC_INSTALL_TARGET)
PYABC_INSTALL_DIR
?=
/hd/common/pyabc/builds/pyabc_builds/
.PHONY
:
zzz
pyabc_install_target
:
pyabc_extension_bdist
mkdir
-p
"$(PYABC_INSTALL_DIR)/$(PYABC_INSTALL_TARGET)"
tar
\
--directory
=
"
$(PYABC_INSTALL_DIR)
/
$(PYABC_INSTALL_TARGET)
"
\
--show-transformed-names
\
--transform
=
's#^.*/##g'
\
-xvzf
"
$(ABC_PYTHON_FILES_PREFIX)
/dist/pyabc-1.0.linux-x86_64.tar.gz"
find
"$(PYABC_INSTALL_DIR)/$(PYABC_INSTALL_TARGET)/"
*
-type
d
|
xargs
rmdir
echo
"Installed at $(PYABC_INSTALL_DIR)/$(PYABC_INSTALL_TARGET)"
endif
endif
src/python/pyabc.i
View file @
34d59b0b
This diff is collapsed.
Click to expand it.
src/python/pyabc_split.py
View file @
34d59b0b
...
@@ -15,7 +15,6 @@ Caveats:
...
@@ -15,7 +15,6 @@ Caveats:
1. Global variables in the parent process are not affected by the child processes.
1. Global variables in the parent process are not affected by the child processes.
2. The functions can only return simple types, see the pickle module for details
2. The functions can only return simple types, see the pickle module for details
3. Signals are currently not handled correctly
Usage:
Usage:
...
@@ -91,47 +90,6 @@ from contextlib import contextmanager
...
@@ -91,47 +90,6 @@ from contextlib import contextmanager
import
pyabc
import
pyabc
def
_waitpid
(
pid
,
flags
):
while
True
:
try
:
res
=
os
.
waitpid
(
pid
,
flags
)
return
res
except
OSError
as
e
:
if
e
.
errno
!=
errno
.
EINTR
:
raise
def
_wait
():
while
True
:
try
:
pid
,
rc
=
os
.
wait
()
return
pid
,
rc
except
OSError
as
e
:
if
e
.
errno
!=
errno
.
EINTR
:
raise
except
Exceptions
as
e
:
raise
class
_sigint_critical_section
(
object
):
def
__init__
(
self
):
self
.
blocked
=
False
def
__enter__
(
self
):
self
.
acquire
()
return
self
def
__exit__
(
self
,
type
,
value
,
traceback
):
self
.
release
()
def
acquire
(
self
):
if
not
self
.
blocked
:
self
.
blocked
=
True
pyabc
.
block_sigint
()
def
release
(
self
):
if
self
.
blocked
:
self
.
blocked
=
False
pyabc
.
restore_sigint_block
()
class
_splitter
(
object
):
class
_splitter
(
object
):
def
__init__
(
self
,
funcs
):
def
__init__
(
self
,
funcs
):
...
@@ -144,17 +102,18 @@ class _splitter(object):
...
@@ -144,17 +102,18 @@ class _splitter(object):
return
len
(
self
.
fds
)
==
0
return
len
(
self
.
fds
)
==
0
def
cleanup
(
self
):
def
cleanup
(
self
):
# close pipes and kill child processes
# close pipes and kill child processes
for
pid
,(
i
,
fd
)
in
self
.
fds
.
iteritems
():
for
pid
,(
i
,
fd
)
in
self
.
fds
.
iteritems
():
os
.
close
(
fd
)
os
.
close
(
fd
)
try
:
os
.
kill
(
pid
,
signal
.
SIGINT
)
os
.
kill
(
pid
,
signal
.
SIGINT
)
except
Exception
as
e
:
print
>>
sys
.
stderr
,
'exception while trying to kill pid=
%
d: '
%
pid
,
e
raise
with
_sigint_critical_section
()
as
cs
:
# wait for termination and update result
# wait for termination and update result
for
pid
,
_
in
self
.
fds
.
iteritems
():
for
pid
,
_
in
self
.
fds
.
iteritems
():
_waitpid
(
pid
,
0
)
os
.
waitpid
(
pid
,
0
)
pyabc
.
remove_child_pid
(
pid
)
self
.
results
[
pid
]
=
None
self
.
results
[
pid
]
=
None
self
.
fds
=
{}
self
.
fds
=
{}
...
@@ -179,20 +138,18 @@ class _splitter(object):
...
@@ -179,20 +138,18 @@ class _splitter(object):
try
:
try
:
with
_sigint_critical_section
()
as
cs
:
# create child process
# create child process
pid
=
os
.
fork
()
pid
=
os
.
fork
()
if
pid
==
0
:
if
pid
==
0
:
# child process:
# child process:
pyabc
.
reset_sigint_handler
()
cs
.
release
()
os
.
close
(
pr
)
os
.
close
(
pr
)
pyabc
.
close_on_fork
(
pw
)
rc
=
self
.
child
(
pw
,
f
)
rc
=
self
.
child
(
pw
,
f
)
os
.
_exit
(
rc
)
os
.
_exit
(
rc
)
else
:
else
:
# parent process:
# parent process:
pyabc
.
add_child_pid
(
pid
)
os
.
close
(
pw
)
os
.
close
(
pw
)
return
(
pid
,
pr
)
return
(
pid
,
pr
)
...
@@ -209,12 +166,9 @@ class _splitter(object):
...
@@ -209,12 +166,9 @@ class _splitter(object):
def
get_next_result
(
self
):
def
get_next_result
(
self
):
# wait for the next child process to terminate
# wait for the next child process to terminate
pid
,
rc
=
_
wait
()
pid
,
rc
=
os
.
wait
()
assert
pid
in
self
.
fds
assert
pid
in
self
.
fds
with
_sigint_critical_section
()
as
cs
:
pyabc
.
remove_child_pid
(
pid
)
# retrieve the pipe file descriptor1
# retrieve the pipe file descriptor1
i
,
fd
=
self
.
fds
[
pid
]
i
,
fd
=
self
.
fds
[
pid
]
del
self
.
fds
[
pid
]
del
self
.
fds
[
pid
]
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment