VirtualBox

Ignore:
Timestamp:
Sep 2, 2008 10:00:59 AM (16 years ago)
Author:
vboxsync
Message:

Solaris/vboxdrv: fixed reboot issue with vboxnetflt and vboxdrv.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/HostDrivers/Support/solaris/SUPDrv-solaris.c

    r11927 r11966  
    201201        LogRel((DEVICE_NAME ":failed to disable autounloading!\n"));
    202202
    203     int rc = ddi_soft_state_init(&g_pVBoxDrvSolarisState, sizeof(vbox_devstate_t), 8);
    204     if (!rc)
    205     {
    206         rc = mod_install(&g_VBoxDrvSolarisModLinkage);
    207         if (!rc)
    208             return 0; /* success */
    209 
    210         ddi_soft_state_fini(&g_pVBoxDrvSolarisState);
    211         LogRel((DEVICE_NAME ":mod_install failed! rc=%d\n", rc));
     203    /*
     204     * Initialize IPRT R0 driver, which internally calls OS-specific r0 init.
     205     */
     206    int rc = RTR0Init(0);
     207    if (RT_SUCCESS(rc))
     208    {
     209        /*
     210         * Initialize the device extension
     211         */
     212        rc = supdrvInitDevExt(&g_DevExt);
     213        if (RT_SUCCESS(rc))
     214        {
     215            /*
     216             * Initialize the session hash table.
     217             */
     218            memset(g_apSessionHashTab, 0, sizeof(g_apSessionHashTab));
     219            rc = RTSpinlockCreate(&g_Spinlock);
     220            if (RT_SUCCESS(rc))
     221            {
     222                int rc = ddi_soft_state_init(&g_pVBoxDrvSolarisState, sizeof(vbox_devstate_t), 8);
     223                if (!rc)
     224                {
     225                    rc = mod_install(&g_VBoxDrvSolarisModLinkage);
     226                    if (!rc)
     227                        return 0; /* success */
     228
     229                    ddi_soft_state_fini(&g_pVBoxDrvSolarisState);
     230                    LogRel((DEVICE_NAME ":mod_install failed! rc=%d\n", rc));
     231                }
     232                else
     233                    LogRel((DEVICE_NAME ":failed to initialize soft state.\n"));
     234
     235                RTSpinlockDestroy(g_Spinlock);
     236                g_Spinlock = NIL_RTSPINLOCK;
     237            }
     238            else
     239                LogRel((DEVICE_NAME ":VBoxDrvSolarisAttach: RTSpinlockCreate failed\n"));
     240            supdrvDeleteDevExt(&g_DevExt);
     241        }
     242        else
     243            LogRel((DEVICE_NAME ":VBoxDrvSolarisAttach: supdrvInitDevExt failed\n"));
     244        RTR0Term();
    212245    }
    213246    else
    214         LogRel((DEVICE_NAME ":failed to initialize soft state.\n"));
    215 
    216     return rc;
     247        LogRel((DEVICE_NAME ":VBoxDrvSolarisAttach: failed to init R0Drv\n"));
     248    memset(&g_DevExt, 0, sizeof(g_DevExt));
     249
     250    return -1;
    217251}
    218252
     
    222256    LogFlow((DEVICE_NAME ":_fini\n"));
    223257
    224     int e = mod_remove(&g_VBoxDrvSolarisModLinkage);
    225     if (e != 0)
    226         return e;
     258    /*
     259     * Undo the work we did at start (in the reverse order).
     260     */
     261    int rc = mod_remove(&g_VBoxDrvSolarisModLinkage);
     262    if (rc != 0)
     263        return rc;
     264
     265    supdrvDeleteDevExt(&g_DevExt);
     266
     267    rc = RTSpinlockDestroy(g_Spinlock);
     268    AssertRC(rc);
     269    g_Spinlock = NIL_RTSPINLOCK;
     270
     271    RTR0Term();
     272
     273    memset(&g_DevExt, 0, sizeof(g_DevExt));
    227274
    228275    ddi_soft_state_fini(&g_pVBoxDrvSolarisState);
    229     return e;
     276    return 0;
    230277}
    231278
     
    270317
    271318            /*
    272              * Initialize IPRT R0 driver, which internally calls OS-specific r0 init.
     319             * Register ourselves as a character device, pseudo-driver
    273320             */
    274             rc = RTR0Init(0);
    275             if (RT_SUCCESS(rc))
     321#ifdef VBOX_WITH_HARDENING
     322            rc = ddi_create_priv_minor_node(pDip, DEVICE_NAME, S_IFCHR, instance, DDI_PSEUDO,
     323                                            0, "all", "all", 0600);
     324#else
     325            rc = ddi_create_priv_minor_node(pDip, DEVICE_NAME, S_IFCHR, instance, DDI_PSEUDO,
     326                                            0, "none", "none", 0666);
     327#endif
     328            if (rc == DDI_SUCCESS)
    276329            {
    277                 /*
    278                  * Initialize the device extension
    279                  */
    280                 rc = supdrvInitDevExt(&g_DevExt);
    281                 if (RT_SUCCESS(rc))
    282                 {
    283                     /*
    284                      * Initialize the session hash table.
    285                      */
    286                     memset(g_apSessionHashTab, 0, sizeof(g_apSessionHashTab));
    287                     rc = RTSpinlockCreate(&g_Spinlock);
    288                     if (RT_SUCCESS(rc))
    289                     {
    290                         /*
    291                          * Register ourselves as a character device, pseudo-driver
    292                          */
    293 #ifdef VBOX_WITH_HARDENING
    294                         rc = ddi_create_priv_minor_node(pDip, DEVICE_NAME, S_IFCHR, instance, DDI_PSEUDO,
    295                                                         0, "all", "all", 0600);
    296 #else
    297                         rc = ddi_create_priv_minor_node(pDip, DEVICE_NAME, S_IFCHR, instance, DDI_PSEUDO,
    298                                                         0, "none", "none", 0666);
     330#ifdef USE_SESSION_HASH
     331                pState->pDip = pDip;
    299332#endif
    300                         if (rc == DDI_SUCCESS)
    301                         {
    302 #ifdef USE_SESSION_HASH
    303                             pState->pDip = pDip;
    304 #endif
    305                             ddi_report_dev(pDip);
    306                             return DDI_SUCCESS;
    307                         }
    308 
    309                         /* Is this really necessary? */
    310                         ddi_remove_minor_node(pDip, NULL);
    311                         LogRel((DEVICE_NAME ":VBoxDrvSolarisAttach: ddi_create_priv_minor_node failed.\n"));
    312 
    313                         RTSpinlockDestroy(g_Spinlock);
    314                         g_Spinlock = NIL_RTSPINLOCK;
    315                     }
    316                     else
    317                         LogRel((DEVICE_NAME ":VBoxDrvSolarisAttach: RTSpinlockCreate failed\n"));
    318                     supdrvDeleteDevExt(&g_DevExt);
    319                 }
    320                 else
    321                     LogRel((DEVICE_NAME ":VBoxDrvSolarisAttach: supdrvInitDevExt failed\n"));
    322                 RTR0Term();
     333                ddi_report_dev(pDip);
     334                return DDI_SUCCESS;
    323335            }
    324             else
    325                 LogRel((DEVICE_NAME ":VBoxDrvSolarisAttach: failed to init R0Drv\n"));
    326             memset(&g_DevExt, 0, sizeof(g_DevExt));
    327             break;
     336           
     337            return DDI_FAILURE;
    328338        }
    329339
     
    371381            ddi_soft_state_free(g_pVBoxDrvSolarisState, instance);
    372382#endif
    373 
    374             supdrvDeleteDevExt(&g_DevExt);
    375 
    376             rc = RTSpinlockDestroy(g_Spinlock);
    377             AssertRC(rc);
    378             g_Spinlock = NIL_RTSPINLOCK;
    379 
    380             RTR0Term();
    381 
    382             memset(&g_DevExt, 0, sizeof(g_DevExt));
    383383            return DDI_SUCCESS;
    384384        }
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