VirtualBox

Changeset 47302 in vbox for trunk/src


Ignore:
Timestamp:
Jul 22, 2013 2:18:41 PM (12 years ago)
Author:
vboxsync
Message:

r0drv/threadctxhooks: Use the right function prototypes on S10, S11 as we might have to use freectx() in which case it does matter.

Location:
trunk/src/VBox/Runtime
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Runtime/r0drv/solaris/initterm-r0drv-solaris.c

    r44528 r47302  
    6767/** The xc_call callout table structure. */
    6868RTR0FNSOLXCCALL                 g_rtSolXcCall;
     69/** Whether to use the old-style installctx()/removectx() routines. */
     70bool                            g_frtSolOldThreadCtx = false;
     71/** The thread-context hooks callout table structure. */
     72RTR0FNSOLTHREADCTX              g_rtSolThreadCtx;
    6973/** Thread preemption offset. */
    7074size_t                          g_offrtSolThreadPreempt;
     
    127131            goto errorbail;
    128132        }
    129         cmn_err(CE_CONT, "!cpu_t::cpu_runrun @ 0x%lx\n",    g_offrtSolCpuPreempt);
    130         cmn_err(CE_CONT, "!cpu_t::cpu_kprunrun @ 0x%lx\n", g_offrtSolCpuForceKernelPreempt);
    131         cmn_err(CE_CONT, "!kthread_t::t_preempt @ 0x%lx\n", g_offrtSolThreadPreempt);
     133        cmn_err(CE_CONT, "!cpu_t::cpu_runrun @ 0x%lx (%ld)\n",    g_offrtSolCpuPreempt, g_offrtSolCpuPreempt);
     134        cmn_err(CE_CONT, "!cpu_t::cpu_kprunrun @ 0x%lx (%ld)\n",  g_offrtSolCpuForceKernelPreempt, g_offrtSolCpuForceKernelPreempt);
     135        cmn_err(CE_CONT, "!kthread_t::t_preempt @ 0x%lx (%ld)\n", g_offrtSolThreadPreempt, g_offrtSolThreadPreempt);
    132136
    133137        /*
     
    161165                goto errorbail;
    162166            }
     167        }
     168
     169        /*
     170         * Mandatory: Thread-context hooks.
     171         */
     172        rc = RTR0DbgKrnlInfoQuerySymbol(g_hKrnlDbgInfo, NULL /* pszModule */, "exitctx",  NULL /* ppvSymbol */);
     173        if (RT_SUCCESS(rc))
     174        {
     175            g_rtSolThreadCtx.Install.pfnSol_installctx = (void *)installctx;
     176            g_rtSolThreadCtx.Remove.pfnSol_removectx =   (void *)removectx;
     177        }
     178        else
     179        {
     180            g_frtSolOldThreadCtx = true;
     181            g_rtSolThreadCtx.Install.pfnSol_installctx_old = (void *)installctx;
     182            g_rtSolThreadCtx.Remove.pfnSol_removectx_old   = (void *)removectx;
    163183        }
    164184
  • trunk/src/VBox/Runtime/r0drv/solaris/the-solaris-kernel.h

    r47206 r47302  
    148148extern bool                     g_frtSolOldIPIUlong;
    149149
     150/*
     151 * Thread-context hooks.
     152 * Workarounds for older Solaris versions that did not have the exitctx() callback.
     153 */
     154typedef struct RTR0FNSOLTHREADCTX
     155{
     156    union
     157    {
     158        void *(*pfnSol_installctx)        (kthread_t *pThread, void *pvArg,
     159                                           void (*pfnSave)(void *pvArg),
     160                                           void (*pfnRestore)(void *pvArg),
     161                                           void (*pfnFork)(void *pvThread, void *pvThreadFork),
     162                                           void (*pfnLwpCreate)(void *pvThread, void *pvThreadCreate),
     163                                           void (*pfnExit)(void *pvThread),
     164                                           void (*pfnFree)(void *pvArg, int fIsExec));
     165
     166        void *(*pfnSol_installctx_old)    (kthread_t *pThread, void *pvArg,
     167                                           void (*pfnSave)(void *pvArg),
     168                                           void (*pfnRestore)(void *pvArg),
     169                                           void (*pfnFork)(void *pvThread, void *pvThreadFork),
     170                                           void (*pfnLwpCreate)(void *pvThread, void *pvThreadCreate),
     171                                           void (*pfnFree)(void *pvArg, int fIsExec));
     172    } Install;
     173
     174    union
     175    {
     176        int (*pfnSol_removectx)           (kthread_t *pThread, void *pvArg,
     177                                           void (*pfnSave)(void *pvArg),
     178                                           void (*pfnRestore)(void *pvArg),
     179                                           void (*pfnFork)(void *pvThread, void *pvThreadFork),
     180                                           void (*pfnLwpCreate)(void *pvThread, void *pvThreadCreate),
     181                                           void (*pfnExit)(void *pvThread),
     182                                           void (*pfnFree)(void *pvArg, int fIsExec));
     183
     184        int (*pfnSol_removectx_old)       (kthread_t *pThread, void *pvArg,
     185                                           void (*pfnSave)(void *pvArg),
     186                                           void (*pfnRestore)(void *pvArg),
     187                                           void (*pfnFork)(void *pvThread, void *pvThreadFork),
     188                                           void (*pfnLwpCreate)(void *pvThread, void *pvThreadCreate),
     189                                           void (*pfnFree)(void *pvArg, int fIsExec));
     190    } Remove;
     191} RTR0FNSOLTHREADCTX;
     192typedef RTR0FNSOLTHREADCTX *PRTR0FNSOLTHREADCTX;
     193
     194extern RTR0FNSOLTHREADCTX       g_rtSolThreadCtx;
     195extern bool                     g_frtSolOldThreadCtx;
    150196
    151197/* Solaris globals. */
  • trunk/src/VBox/Runtime/r0drv/solaris/threadctxhooks-r0drv-solaris.c

    r47206 r47302  
    121121     * invoke the consumer's hook or not.
    122122     */
    123     installctx(curthread,
    124                pThis,
    125                rtThreadCtxHooksSolPreempting,
    126                rtThreadCtxHooksSolResumed,
    127                NULL,                            /* fork */
    128                NULL,                            /* lwp_create */
    129                NULL,                            /* exit */
    130                NULL);                           /* free */
     123    if (g_frtSolOldThreadCtx)
     124    {
     125        g_rtSolThreadCtx.Install.pfnSol_installctx_old(curthread,
     126                                                       pThis,
     127                                                       rtThreadCtxHooksSolPreempting,
     128                                                       rtThreadCtxHooksSolResumed,
     129                                                       NULL,                          /* fork */
     130                                                       NULL,                          /* lwp_create */
     131                                                       NULL);                         /* free */
     132    }
     133    else
     134    {
     135        g_rtSolThreadCtx.Install.pfnSol_installctx(curthread,
     136                                                   pThis,
     137                                                   rtThreadCtxHooksSolPreempting,
     138                                                   rtThreadCtxHooksSolResumed,
     139                                                   NULL,                              /* fork */
     140                                                   NULL,                              /* lwp_create */
     141                                                   NULL,                              /* exit */
     142                                                   NULL);                             /* free */
     143    }
    131144
    132145    *phThreadCtx = pThis;
     
    151164     * Deregister the hook.
    152165     */
    153     int rc = removectx(curthread,
    154                        pThis,
    155                        rtThreadCtxHooksSolPreempting,
    156                        rtThreadCtxHooksSolResumed,
    157                        NULL,                            /* fork */
    158                        NULL,                            /* lwp_create */
    159                        NULL,                            /* exit */
    160                        NULL);                           /* free */
     166    int rc;
     167    if (g_frtSolOldThreadCtx)
     168    {
     169        rc = g_rtSolThreadCtx.Remove.pfnSol_removectx_old(curthread,
     170                                                          pThis,
     171                                                          rtThreadCtxHooksSolPreempting,
     172                                                          rtThreadCtxHooksSolResumed,
     173                                                          NULL,                          /* fork */
     174                                                          NULL,                          /* lwp_create */
     175                                                          NULL);                         /* free */
     176    }
     177    else
     178    {
     179        rc = g_rtSolThreadCtx.Remove.pfnSol_removectx(curthread,
     180                                                      pThis,
     181                                                      rtThreadCtxHooksSolPreempting,
     182                                                      rtThreadCtxHooksSolResumed,
     183                                                      NULL,                              /* fork */
     184                                                      NULL,                              /* lwp_create */
     185                                                      NULL,                              /* exit */
     186                                                      NULL);                             /* free */
     187    }
    161188    AssertMsg(rc, ("removectx failed. rc=%d\n", rc));
    162189    NOREF(rc);
  • trunk/src/VBox/Runtime/testcase/tstR0ThreadPreemption.cpp

    r47206 r47302  
    293293            }
    294294
    295             PTSTRTR0THREADCTXDATA pCtxData = (PTSTRTR0THREADCTXDATA)RTMemAlloc(sizeof(*pCtxData));
     295            PTSTRTR0THREADCTXDATA pCtxData = (PTSTRTR0THREADCTXDATA)RTMemAllocZ(sizeof(*pCtxData));
    296296            AssertReturn(pCtxData, VERR_NO_MEMORY);
    297297            pCtxData->u32Magic           = TSTRTR0THREADCTXDATA_MAGIC;
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette