summaryrefslogtreecommitdiff
path: root/amigaos4/amigaio.c
diff options
context:
space:
mode:
authorAndy Broad <andy@broad.ology.org.uk>2015-09-15 09:01:12 -0400
committerJarkko Hietaniemi <jhi@iki.fi>2015-09-16 07:44:30 -0400
commitef2467ad52d6d3d5c8086ea82c0de73f7b6f3c93 (patch)
tree5f558b96fe69e1cf9ed8af55d1cf3a9219df5000 /amigaos4/amigaio.c
parent1cd70adfb6a06a0dc72d31fc7011592a3674b183 (diff)
downloadperl-ef2467ad52d6d3d5c8086ea82c0de73f7b6f3c93.tar.gz
amigaos4: better kill() implementation
(the underlying UNIX emulation has changed)
Diffstat (limited to 'amigaos4/amigaio.c')
-rw-r--r--amigaos4/amigaio.c27
1 files changed, 27 insertions, 0 deletions
diff --git a/amigaos4/amigaio.c b/amigaos4/amigaio.c
index 53f059ff81..400f8d015c 100644
--- a/amigaos4/amigaio.c
+++ b/amigaos4/amigaio.c
@@ -89,6 +89,7 @@ struct thread_info
int ti_children;
pthread_t ti_parent;
struct MsgPort *ti_port;
+ struct Process *ti_Process;
};
static struct thread_info pseudo_children[MAX_THREADS];
@@ -154,6 +155,31 @@ struct child_arg
PerlInterpreter *ca_interp;
};
+#undef kill
+
+/* FIXME: Is here's a chance, albeit it small of a clash between our pseudo pid */
+/* derived from the pthread API and the dos.library pid that newlib kill uses? */
+/* clib2 used the Process address so there was no issue */
+
+int amigaos_kill(Pid_t pid, int signal)
+{
+ int i;
+ Pid_t realpid = pid; // Perhaps we have a real pid from else where?
+ /* Look for our DOS pid */
+ IExec->ObtainSemaphore(&fork_array_sema);
+ for (i = 0; i < MAX_THREADS; i++)
+ {
+ if (pseudo_children[i].ti_pid == pid)
+ {
+ realpid = (Pid_t)IDOS->GetPID(pseudo_children[i].ti_Process,GPID_PROCESS);
+ break;
+ }
+ }
+ IExec->ReleaseSemaphore(&fork_array_sema);
+ /* Allow the C library to work out which signals are realy valid */
+ return kill(realpid,signal);
+}
+
static THREAD_RET_TYPE amigaos4_start_child(void *arg)
{
@@ -183,6 +209,7 @@ static THREAD_RET_TYPE amigaos4_start_child(void *arg)
nextchild = getnextchild();
pseudo_children[nextchild].ti_pid = pseudo_id;
+ pseudo_children[nextchild].ti_Process = (struct Process *)IExec->FindTask(NULL);
pseudo_children[nextchild].ti_parent =
((struct child_arg *)arg)->ca_parent;
pseudo_children[nextchild].ti_port =