It appears you can just use the siginfo_t * as the struct sigcontext *
!!!!!!
ie
void *signal_handler(int signo, siginfo_t *siginfoptr, struct sigcontext
*scp)
{
     scp = (struct sigcontext_struct *)siginfoptr;
     /* the rest of your code, here */
}


John Kacur/Toronto/IBM@IBMCA
[EMAIL PROTECTED]
(416) 448-2584 (phone)
778-2584 (tie line)


"Kevin B. Hendricks" <[EMAIL PROTECTED]> on 01/25/2001 02:02:20 PM

Please respond to [EMAIL PROTECTED]

To:   John Kacur/Toronto/IBM@IBMCA
cc:
Subject:  Re: [Fwd: sigcontext on Linux-ppc in user space]


Hi,

Just in case this helps,  here is what I did to accomplish the same thing
in the green_threads jdk.  It definitely is not portable.

Kevin

Inside the signal handler:

#elif defined(__linux__) && defined(__powerpc__)
    /* get the value of r1 (the stack pointer) */
    long * p;
    struct sigcontext_struct * scp;
    __asm__ ( "addi %0,1,0" : "=r" (p) : /* no inputs */ );
    /* follow it back up the chain */
    p = *p;
    /* from here the sigcontext struct is 64 bytes away */
    p = p + 16;
    scp = (struct sigcontext_struct *)p;

On Thursday, January 25, 2001, at 01:50 PM, [EMAIL PROTECTED] wrote:

>
> Ok, actually the segfault was for a more complicated function, but the
> simplified example still gives the wrong answer. i.e scp should point to
a
> struct sigcontext and scp->signal should be 10 in the sample program.
>
> John Kacur/Toronto/IBM@IBMCA
> [EMAIL PROTECTED]
> (416) 448-2584 (phone)
> 778-2584 (tie line)
>
>
> "Kevin B. Hendricks" <[EMAIL PROTECTED]> on 01/25/2001 01:10:40 PM
>
> Please respond to [EMAIL PROTECTED]
>
> To:   John Kacur/Toronto/IBM@IBMCA
> cc:   [EMAIL PROTECTED], [EMAIL PROTECTED]
> Subject:  Re: [Fwd: sigcontext on Linux-ppc in user space]
>
>
> Hi,
>
> Here is what I get from running it on my system (ppc linux with 2.2.15
> kernel with some mods and glibc-2.1.3).
>
> But no segfault.
>
> Kevin
>
>
> [kbhend@localhost ~]$ gcc -O2 -ojunk junk.c
> [kbhend@localhost ~]$ ./junk
> SIGUSR1 = 10
> scp = 7fffe9a4
> scp->signal = 0
> [kbhend@localhost ~]$
>
>
>
>
> On Thursday, January 25, 2001, at 10:09 AM, [EMAIL PROTECTED] wrote:
>
> > #include <stdio.h>
> > #include <signal.h>
> >
> > /* Function Prototypes */
> > void install_sigusr1_handler(void);
> > void sigusr_handler(int , siginfo_t *, struct sigcontext * scp);
> >
> > int main(void)
> > {
> >         install_sigusr1_handler();
> >         printf("SIGUSR1 = %d\n", SIGUSR1);
> >         raise(SIGUSR1);
> >         exit(0);
> > }
> >
> > void install_sigusr1_handler(void)
> > {
> >         struct sigaction newAct;
> >
> >         if (sigemptyset(&newAct.sa_mask) != 0) {
> >                 fprintf(stderr, "Warning, sigemptyset failed.\n");
> >         }
> >
> >         newAct.sa_flags = 0;
> >         newAct.sa_flags |= SA_SIGINFO | SA_RESTART;
> >
> >         newAct.sa_sigaction = (void
> > (*)(int,siginfo_t*,void*))sigusr_handler;
> >
> >         if (sigaction(SIGUSR1, &newAct, NULL) != 0) {
> >                 fprintf(stderr, "Couldn't install SIGUSR1 handler.\n");

> >                 fprintf(stderr, "Exiting.\n");
> >                 exit(1);
> >         }
> > }
> >
> > void sigusr_handler(int signo, siginfo_t *siginfp, struct sigcontext *
> scp)
> > {
> >         printf("scp = %08x\n", scp);
> >         printf("scp->signal = %d\n", scp->signal);
> > }
> >
> >
>
>
>
>




-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
Please read the FAQ at http://www.tux.org/lkml/

Reply via email to