Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 3 Feb 2011 10:59:32 +0000 (UTC)
From:      "Bjoern A. Zeeb" <bzeeb-lists@lists.zabbadoz.net>
To:        Monthadar Al Jaberi <monthadar@gmail.com>
Cc:        FreeBSD virtualization mailing list <freebsd-virtualization@freebsd.org>
Subject:   Re: simulating wireless device (if_alloc panic, VirtualBox, VIMAGE)
Message-ID:  <20110203105747.K80258@maildrop.int.zabbadoz.net>
In-Reply-To: <AANLkTinY0AVSsEE5PZaJOqyuinsAN6wkUL9URAqYs0X4@mail.gmail.com>
References:  <AANLkTik8D_bLwcUKZdBT-kpkJdDXtPTLvAqfUe0cLoSz@mail.gmail.com> <4D484213.6050100@freebsd.org> <AANLkTikJKZLQVA5X2PQs0oT4iFsZYBw7K07kjQTc9iGD@mail.gmail.com> <4D486108.5060805@freebsd.org> <AANLkTi=mk2vfyXJBaK5mV2sBWEj0-RDZneLs%2BXq_c7sb@mail.gmail.com> <20110202164827.I80258@maildrop.int.zabbadoz.net> <4D4994CE.2090209@freebsd.org> <AANLkTimDZRefv57_nanxGUbHjP1wqeQ41iWHvpXogmvU@mail.gmail.com> <4D49AB29.7070909@freebsd.org> <AANLkTinONnLE9D=c57nQmGBFbWJgqJmeKiRViW3gga2a@mail.gmail.com> <20110203095019.N80258@maildrop.int.zabbadoz.net> <AANLkTinY0AVSsEE5PZaJOqyuinsAN6wkUL9URAqYs0X4@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
  This message is in MIME format.  The first part should be readable text,
  while the remaining parts are likely unreadable without MIME-aware tools.

--0-100765273-1296730772=:80258
Content-Type: TEXT/PLAIN; charset=ISO-8859-1; format=flowed
Content-Transfer-Encoding: QUOTED-PRINTABLE

On Thu, 3 Feb 2011, Monthadar Al Jaberi wrote:

>>>> I don't understand why you saw a CRED_TO_VNET of 0
>>>> I was under the impression that every process/thread in the system wou=
ld
>>>> be
>>>> on vnet0
>>>> in a vimage kernel.
>>>
>>> This is how my printf looks like:
>>> struct thread *td =3D curthread;
>>> struct vnet *v =3D TD_TO_VNET(td);
>>> struct ucred *cred =3D CRED_TO_VNET(td->ucred);
>>> struct vnet *td_vnet =3D td->td_vnet;
>>
>> here's your problem:
>>
>> strcut vnet *vnet =3D cred->cr_prison->pr_vnet;
>
> When I add CURVNET_SET(CRED_TO_VNET(curthread->td_ucred)); I get a panic =
too...
> But your suggestion works if I do like this:
> curthread->td_vnet =3D curthread->td_ucred->cr_prison->pr_vnet;
>
> CRED_TO_VNET(curthread->td_ucred) returns NULL

I wonder how you are building your module and if VIMAGE is properly
defined.  If it's not that would explain a lot of things.


>>> printf("td=3D%p, td->td_vnet=3D%p, td->td_ucred=3D%p, TD_TO_VNET=3D%p,
>>> CRED_TO_VNET=3D%p\n", td, td_vnet, td->td_ucred, v, cred);
>>>
>>> I made a fast search in /usr/src for "td_vnet" and found it was
>>> assigned only in
>>> int fork1(td, flags, pages, procp):
>>> #ifdef VIMAGE
>>> =A0 =A0 =A0 =A0td2->td_vnet =3D NULL;
>>> =A0 =A0 =A0 =A0td2->td_vnet_lpush =3D NULL;
>>> #endif
>>
>> Nice try. =A0Want another search? =A0Hint: there is this in vnet.h:
>>
>> #define curvnet curthread->td_vnet
>>
>> And then you'll, again, find the CURVNET_SET_* macros.
>
> Thank you

Something you may find useful as well btw is:

http://people.freebsd.org/~bz/20100530-02.vnet.9.html

--=20
Bjoern A. Zeeb                                 You have to have visions!
         <ks> Going to jail sucks -- <bz> All my daemons like it!
   http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/jails.html
--0-100765273-1296730772=:80258--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20110203105747.K80258>