[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Xen-devel] Front-end back-end connection



On Thu, Oct 13, 2011 at 8:08 PM, Ian Campbell <Ian.Campbell@xxxxxxxxxx> wrote:
> On Thu, 2011-10-13 at 11:34 +0100, Daniel Castro wrote:
>> On Wed, Oct 12, 2011 at 10:56 PM, Ian Campbell <Ian.Campbell@xxxxxxxxxx> 
>> wrote:
>> > On Wed, 2011-10-12 at 13:02 +0100, Daniel Castro wrote:
>> >> On Wed, Oct 12, 2011 at 7:12 PM, Ian Campbell <Ian.Campbell@xxxxxxxxxx> 
>> >> wrote:
>> >> > On Wed, 2011-10-12 at 08:13 +0100, Daniel Castro wrote:
>> >> >> Hello All,
>> >> >>
>> >> >> I am in the process of conecting my front-end to my back end.
>> >> >> The process is like this:
>> >> >> 1. Set up xenstore conection
>> >> >> 2. initiate front rings
>> >> >> 3. Initiate gran table
>> >> >> 4. Take my rings mfn address and set it up as a entry (more on this)
>> >> >> 5. create a unbound port for front-back ring communication (more on 
>> >> >> this )
>> >> >> 5.1 I start by changing state to XenbusStateInitialising
>> >> >> 5.2 ring-ref entry (step 4)
>> >> >> 5.3 port entry (step 5)
>> >> >> 5.4 backend state is XenbusStateInitWait
>> >> >> 5.4 change state to XenbusStateInitialised
>> >> >> 5.5 back end state is XenbusStateClosing meaning there is an error or
>> >> >> something is missing.
>> >> >> 6. on sucess end
>> >> >>
>> >> >> More on step 4: I got my grant page table like this:
>> >> >>       struct gnttab_setup_table gst;
>> >> >>       grant_entries = (struct grant_entry_v1 *) memalign_high(4096, 
>> >> >> 4096);
>> >> >> //asume malloc
>> >> >>       memset(grant_entries,0,4096);
>> >> >>       gst.dom = DOMID_SELF; //&me
>> >> >>       gst.nr_frames = 1; //a single page
>> >> >>       //gst.frame_list = grant_entries; (I have no idea how to handle 
>> >> >> this :P )
>> >> >>       res = hypercall_grant_table_op(GNTTABOP_map_grant_ref, &gst, 1);
>> >> >> I think this works, but maybe I am wrong.
>> >> >
>> >> > I'm afraid you are.
>> >> >
>> >> > For one thing simply not initialising one of the fields in the argument
>> >> > structure is unlikely to be correct.
>> >> >
>> >> > Secondly the argument to GNTTABOP_map_grant_ref is a pointer to "struct
>> >> > gnttab_map_grant_ref" not "struct gnttab_setup_table", likewise "struct
>> >> > gnttab_setup_table" goes with GNTTABOP_setup_table. I think this should
>> >> > be pretty clear from the way the GNTTABOP_* and struct definitions are
>> >> > laid out in xen/include/public/grant_table.h and the naming convention
>> >> > what goes with what. There are also comments in that header describing
>> >> > each operation.
>> >> >
>> >> > If you are trying to setup the grant table itself then
>> >> > GNTTABOP_setup_table is what you want. GNTTABOP_map_grant_ref is used
>> >> > for mapping a grant reference which you have been given by another
>> >> > domain.
>> >> >
>> >> > drivers/xen/grant-table.c:gnttab_map should provide a rough idea how
>> >> > this needs to be done. Because this is an HVM domain you need to do a
>> >> > XENMEM_add_to_physmap of XENMAPSPACE_grant_table before you do the
>> >> > GNTTABOP_setup_table.
>> >>
>> >> Fixed. Yet, how can I confirm that the grant table was correctly
>> >> mapped? The hypercall returned 0 and the status in the struct is also
>> >> 0.
>> >> After the mapping I am printing this:
>> >> allocated grant_entries at 12 bytes at 0x0f7fc000, gpfn 0xf7fc
>> >> GNTTABOP_setup_table return 0 status:0
>> >> allocated shared info 2584 bytes at 0x0f7fa000, gpfn 0xf7fa
>> >
>> > Did you also call XENMEM_add_to_physmap somewhere?
>> Its working now after the changes, and also I noticed that back-end
>> does not read  key "port", instead read "event-channel" so I left both
>> in case.
>
> You only need to fill in the one which the backend reads. That is
> "event-channel".
>
>> For completeness and future references to the list here is my code:
>> static struct grant_entry_v1 *grant_entries = NULL;
>>     struct xen_add_to_physmap xatp;
>>     if(grant_entries!=NULL)
>>               return grant_entries;
>>     xatp.domid = DOMID_SELF;
>>     xatp.space = XENMAPSPACE_grant_table;
>>     xatp.idx   = 0;
>>     grant_entries = (struct grant_entry_v1 *) memalign_high(PAGE_SIZE,
>> PAGE_SIZE);
>>     memset(grant_entries, 0, PAGE_SIZE);
>>     xatp.gpfn  = ((unsigned long)grant_entries >> PAGE_SHIFT);
>>     dprintf(1, "allocated grant_entries at %d bytes at %p, gpfn
>> 0x%lx\n",sizeof(*grant_entries), grant_entries, xatp.gpfn);
>>     if (hypercall_memory_op(XENMEM_add_to_physmap, &xatp) != 0)
>>       panic("MAP grant_entries info page fail");
>>     return grant_entries;
>>
>> struct gnttab_setup_table gst;
>>       grant_entries = (struct grant_entry_v1 *) get_grant_table();
>>       gst.dom = DOMID_SELF;
>>       gst.nr_frames = 1;
>>       //gst.frame_list = (struct grant_entry_v1 *) grant_entries;
>
> This isn't needed? That would surprise me...
Its part of the " OUT parameters. " in the struct, so I did not fill it out...
>
>>       res = hypercall_grant_table_op(GNTTABOP_setup_table, &gst, 1);
>>       if(res!=0){
>>               dprintf(1,"Error Mapping Grant Table... Abort...\n");
>>               panic("Map Grant Table Failed\n");
>>       }
>>       dprintf(1,"GNTTABOP_setup_table return %d status:%d\n",res,gst.status);
>>
>> After this two pieces of code I create the grant entry for the rings
>> as previously discussed.
>> Must fill in device details from xenstore, and, now that the back and
>> front connect I have to handle requests, read and write.
>>
>> I guess is a matter of copy from buffer to ring, and from ring to buffer...
>
> The block protocol involves granting the buffer and putting the ref on
> the ring, not putting data inline in the ring.
>
> However for simplicity I would suggest granting a static buffer to the
> backend and copying from the SeaBIOS buffer to that.
So would it be better to create another static buffer get a gref for
it and copy from disk_op_s->buf_fl when reading and copy to when
writing?

BTW what are segments in SeaBIOS and whats the use for it? in Xen is
only 32 Bit flat right? so I do not have to use any of the segment
macros, right?

Thanks for the help :)

>
>>
>> >
>> > I'm afraid these messages are pretty meaningless without the
>> > corresponding code, but you should certainly have already setup the
>> > table before you start allocating grant_entries in it (or more
>> > importantly writing to them). These messages suggest that is not the
>> > case?
>> >
>> >> I also found that the port I get from the EVTCHNOP_alloc_unbound is 4,
>> >> but lsevtchn gets me this:
>> >>   42: VCPU 0: Interdomain (Connected) - Remote Domain 5, Port 2
>> >>   43: VCPU 0: Interdomain (Connected) - Remote Domain 5, Port 3
>> >>   44: VCPU 0: Interdomain (Connected) - Remote Domain 5, Port 1
>> >> Port 4 is not listed, is it because it is not connected yet?
>> >
>> > If this is lsevtchn for dom0 then most likely yes. You should be able to
>> > see the guest's state with lsevtchn <domid>.
>> >
>> > In the backend the evtchn gets bound after the frontend's shared ring is
>> > mapped so the fact that the evtchn didn't get bound suggests an error
>> > before that point.
>> >
>> >> I get no errors in xl dmesg, and in dmesg I get:
>> >> vbd vbd-5-768: 2 reading /local/domain/5/device/vbd/768/ring-ref and
>> >> event-channel
>> >
>> > Do you see anything else in xenstore?
>> >
>> >> I guess there are the keys I write in the front-end, so they are being 
>> >> read.
>> >>
>> >> Thanks for the help, I feel we are getting closer to the other side...
>> >>
>> >> Daniel
>> >>
>> >> >
>> >> >>  This is needed on step 5, so..
>> >> >> More on step 5:
>> >> >> I consider the grant table an array of type struct grant_entry_v1.
>> >> >> So I simply do grant_entry_v1[0] for my first grant entry, and so
>> >> >> forth. For this case I read on the list some time ago that entry 0 did
>> >> >> not work, so I work with entry 1, like this:
>> >> >> grant_entries[aval_grant].domid = ext_domid;
>> >> >> grant_entries[aval_grant].frame = _frame; where frame is: (u32)sring
>> >> >> >> PAGE_SHIFT //meaning mfn of my rings.
>> >> >> grant_entries[aval_grant].flags = GTF_permit_access;
>> >> >
>> >> > This looks approximately correct _if_ you were actually writing to some
>> >> > memory which was your grant table but due to the above I think you are
>> >> > not.
>> >> >
>> >> >> These last two steps I described may be wrong... I know this because
>> >> >> the backend state is not XenbusStateConnected.
>> >> >
>> >> > That fact alone can't tell you much other than _something_ went wrong.
>> >> >
>> >> > Since the backend will have transitioned to XenbusStateClosing by
>> >> > calling xenbus_dev_fatal() it will have written some error information
>> >> > to xenstore and the dom0 console which should hint at what actually went
>> >> > wrong. I expect you will see the message "mapping ring-ref %lu port %u"
>> >> > because xen_blkif_map will have failed during map_frontend_page().
>> >> >
>> >> >> I think my mistake is on step 5, so can someone please shed some light
>> >> >> on this small issue.
>> >> >>
>> >> >> And thank you very much for taking the time to read.
>> >> >>
>> >> >> Daniel
>> >> >>
>> >> >
>> >> >
>> >> >
>> >>
>> >>
>> >>
>> >
>> >
>> >
>>
>>
>>
>
>
>



-- 
+-=====---------------------------+
| +---------------------------------+ | This space intentionally blank
for notetaking.
| |   | Daniel Castro,                |
| |   | Consultant/Programmer.|
| |   | U Andes                         |
+-------------------------------------+

_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.