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

Re: [Xen-devel] [PATCH v2 13/18] OvmfPkg/XenBusDxe: Add XenStore function into the XenBus protocol



On Thu, Sep 04, 2014 at 05:51:08PM +0100, Anthony PERARD wrote:
> Contributed-under: TianoCore Contribution Agreement 1.0
> Signed-off-by: Anthony PERARD <anthony.perard@xxxxxxxxxx>

Reviewed-by: Konrad Rzeszutek Wilk <konrad.wilk@xxxxxxxxxx>

> ---
>  OvmfPkg/Include/Protocol/XenBus.h | 103 ++++++++++++++++++++++++
>  OvmfPkg/XenBusDxe/XenStore.c      | 160 
> ++++++++++++++++++++++++++++++++++++++
>  OvmfPkg/XenBusDxe/XenStore.h      |  87 +++++++++++++++++++++
>  3 files changed, 350 insertions(+)
> 
> diff --git a/OvmfPkg/Include/Protocol/XenBus.h 
> b/OvmfPkg/Include/Protocol/XenBus.h
> index b10c143..99e174b 100644
> --- a/OvmfPkg/Include/Protocol/XenBus.h
> +++ b/OvmfPkg/Include/Protocol/XenBus.h
> @@ -81,6 +81,62 @@ typedef enum {
>  /// Function prototypes
>  ///
>  
> +/*
> + * Return error from xs_read
> + * Return value of the node ${This->Node}/${node}
> + */
> +typedef
> +XENSTORE_STATUS
> +(EFIAPI *XENBUS_XS_READ)(
> +  IN  XENBUS_PROTOCOL       *This,
> +  IN  XENSTORE_TRANSACTION  Transaction,
> +  IN  CONST CHAR8           *Node,
> +  OUT VOID                  **Result
> +  );
> +
> +typedef
> +XENSTORE_STATUS
> +(EFIAPI *XENBUS_XS_BACKEND_READ)(
> +  IN  XENBUS_PROTOCOL       *This,
> +  IN  XENSTORE_TRANSACTION  Transaction,
> +  IN  CONST CHAR8           *Node,
> +  OUT VOID                  **Result
> +  );
> +
> +typedef
> +XENSTORE_STATUS
> +(EFIAPI *XENBUS_XS_PRINTF) (
> +  IN XENBUS_PROTOCOL        *This,
> +  IN XENSTORE_TRANSACTION   Transaction,
> +  IN CONST CHAR8            *Directory,
> +  IN CONST CHAR8            *Node,
> +  IN CONST CHAR8            *Format,
> +  ...
> +  );
> +
> +typedef
> +XENSTORE_STATUS
> +(EFIAPI *XENBUS_XS_REMOVE) (
> +  IN XENBUS_PROTOCOL        *This,
> +  IN XENSTORE_TRANSACTION   Transaction,
> +  IN CONST CHAR8            *Node
> +  );
> +
> +typedef
> +XENSTORE_STATUS
> +(EFIAPI *XENBUS_XS_TRANSACTION_START)(
> +  IN  XENBUS_PROTOCOL       *This,
> +  OUT XENSTORE_TRANSACTION  *Transaction
> +  );
> +
> +typedef
> +XENSTORE_STATUS
> +(EFIAPI *XENBUS_XS_TRANSACTION_END) (
> +  IN XENBUS_PROTOCOL        *This,
> +  IN XENSTORE_TRANSACTION   Transaction,
> +  IN BOOLEAN                Abort
> +  );
> +
>  typedef
>  EFI_STATUS
>  (EFIAPI *XENBUS_GRANT_ACCESS)(
> @@ -98,16 +154,63 @@ EFI_STATUS
>    IN grant_ref_t      Ref
>    );
>  
> +typedef
> +XENSTORE_STATUS
> +(EFIAPI *XENBUS_REGISTER_WATCH) (
> +  IN  XENBUS_PROTOCOL *This,
> +  IN  CONST CHAR8     *Node,
> +  // XENSTORE_WATCH ?
> +  OUT VOID            **Token
> +  );
> +
> +typedef
> +XENSTORE_STATUS
> +(EFIAPI *XENBUS_REGISTER_WATCH_BACKEND) (
> +  IN  XENBUS_PROTOCOL *This,
> +  IN  CONST CHAR8     *Node,
> +  OUT VOID            **Token
> +  );
> +
> +typedef
> +VOID
> +(EFIAPI *XENBUS_UNREGISTER_WATCH) (
> +  IN XENBUS_PROTOCOL  *This,
> +  IN VOID             *Token
> +  );
> +
> +typedef
> +VOID
> +(EFIAPI *XENBUS_WAIT_FOR_WATCH) (
> +  IN XENBUS_PROTOCOL  *This,
> +  IN VOID             *Token
> +  );
> +
>  
>  ///
>  /// Protocol structure
>  ///
>  struct _XENBUS_PROTOCOL {
> +  XENBUS_XS_READ                XsRead;
> +  XENBUS_XS_BACKEND_READ        XsBackendRead;
> +  XENBUS_XS_PRINTF              XsPrintf;
> +  XENBUS_XS_REMOVE              XsRemove;
> +  XENBUS_XS_TRANSACTION_START   XsTransactionStart;
> +  XENBUS_XS_TRANSACTION_END     XsTransactionEnd;
> +
>    XENBUS_GRANT_ACCESS           GrantAccess;
>    XENBUS_GRANT_END_ACCESS       GrantEndAccess;
> +
> +  XENBUS_REGISTER_WATCH         RegisterWatch;
> +  XENBUS_REGISTER_WATCH_BACKEND RegisterWatchBackend;
> +  XENBUS_UNREGISTER_WATCH       UnregisterWatch;
> +  XENBUS_WAIT_FOR_WATCH         WaitForWatch;
>    //
>    // Protocol data fields
>    //
> +  CONST CHAR8                   *Type;
> +  UINT16                        DeviceId;
> +  CONST CHAR8                   *Node;
> +  CONST CHAR8                   *Backend;
>  };
>  
>  extern EFI_GUID gXenBusProtocolGuid;
> diff --git a/OvmfPkg/XenBusDxe/XenStore.c b/OvmfPkg/XenBusDxe/XenStore.c
> index bcf6e1c..d828c06 100644
> --- a/OvmfPkg/XenBusDxe/XenStore.c
> +++ b/OvmfPkg/XenBusDxe/XenStore.c
> @@ -892,6 +892,42 @@ XenStoreUnwatch (
>    return XenStoreTalkv (XST_NIL, XS_UNWATCH, WriteRequest, 2, NULL, NULL);
>  }
>  
> +STATIC
> +VOID
> +XenStoreWaitWatch (
> +  VOID *Token
> +  )
> +{
> +  XENSTORE_MESSAGE *Message;
> +  LIST_ENTRY *Entry = NULL;
> +  LIST_ENTRY *Last = NULL;
> +
> +  while (TRUE) {
> +    EfiAcquireLock (&xs.WatchEventsLock);
> +    if (IsListEmpty (&xs.WatchEvents) ||
> +        Last == GetFirstNode (&xs.WatchEvents)) {
> +      EfiReleaseLock (&xs.WatchEventsLock);
> +      XenStoreProcessMessage ();
> +      continue;
> +    }
> +
> +    for (Entry = GetFirstNode (&xs.WatchEvents);
> +         Entry != Last && !IsNull (&xs.WatchEvents, Entry);
> +         Entry = GetNextNode (&xs.WatchEvents, Entry)) {
> +      Message = XENSTORE_MESSAGE_FROM_LINK (Entry);
> +      if (Message->u.Watch.Handle == Token) {
> +        RemoveEntryList (Entry);
> +        EfiReleaseLock (&xs.WatchEventsLock);
> +        FreePool(Message->u.Watch.Vector);
> +        FreePool(Message);
> +        return;
> +      }
> +    }
> +    Last = GetFirstNode (&xs.WatchEvents);
> +    EfiReleaseLock (&xs.WatchEventsLock);
> +  }
> +}
> +
>  VOID
>  EFIAPI
>  NotifyEventChannelCheckForEvent (
> @@ -1318,3 +1354,127 @@ XenStoreUnregisterWatch (
>    FreePool (Watch->Node);
>    FreePool (Watch);
>  }
> +
> +
> +//
> +// XENBUS protocol
> +//
> +
> +VOID
> +EFIAPI
> +XenBusWaitForWatch (
> +  IN XENBUS_PROTOCOL *This,
> +  IN VOID *Token
> +  )
> +{
> +  XenStoreWaitWatch (Token);
> +}
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreRead (
> +  IN  XENBUS_PROTOCOL       *This,
> +  IN  XENSTORE_TRANSACTION  Transaction,
> +  IN  CONST CHAR8           *Node,
> +  OUT VOID                  **Value
> +  )
> +{
> +  return XenStoreRead (Transaction, This->Node, Node, NULL, Value);
> +}
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreBackendRead (
> +  IN  XENBUS_PROTOCOL       *This,
> +  IN  XENSTORE_TRANSACTION  Transaction,
> +  IN  CONST CHAR8           *Node,
> +  OUT VOID                  **Value
> +  )
> +{
> +  return XenStoreRead (Transaction, This->Backend, Node, NULL, Value);
> +}
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreRemove (
> +  IN XENBUS_PROTOCOL        *This,
> +  IN XENSTORE_TRANSACTION   Transaction,
> +  IN const char             *Node
> +  )
> +{
> +  return XenStoreRemove (Transaction, This->Node, Node);
> +}
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreTransactionStart (
> +  IN  XENBUS_PROTOCOL       *This,
> +  OUT XENSTORE_TRANSACTION  *Transaction
> +  )
> +{
> +  return XenStoreTransactionStart (Transaction);
> +}
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreTransactionEnd (
> +  IN XENBUS_PROTOCOL        *This,
> +  IN XENSTORE_TRANSACTION   Transaction,
> +  IN BOOLEAN                Abort
> +  )
> +{
> +  return XenStoreTransactionEnd (Transaction, Abort);
> +}
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreSPrint (
> +  IN XENBUS_PROTOCOL        *This,
> +  IN XENSTORE_TRANSACTION   Transaction,
> +  IN CONST CHAR8            *DirectoryPath,
> +  IN CONST CHAR8            *Node,
> +  IN CONST CHAR8            *FormatString,
> +  ...
> +  )
> +{
> +  VA_LIST Marker;
> +  XENSTORE_STATUS Status;
> +
> +  VA_START (Marker, FormatString);
> +  Status = XenStoreVSPrint (Transaction, DirectoryPath, Node, FormatString, 
> Marker);
> +  VA_END (Marker);
> +
> +  return Status;
> +}
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusRegisterWatch (
> +  IN  XENBUS_PROTOCOL *This,
> +  IN  CONST CHAR8     *Node,
> +  OUT VOID            **Token
> +  )
> +{
> +  return XenStoreRegisterWatch (This->Node, Node, (XENSTORE_WATCH **) Token);
> +}
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusRegisterWatchBackend (
> +  IN  XENBUS_PROTOCOL *This,
> +  IN  CONST CHAR8     *Node,
> +  OUT VOID            **Token
> +  )
> +{
> +  return XenStoreRegisterWatch (This->Backend, Node, (XENSTORE_WATCH **) 
> Token);
> +}
> +
> +VOID
> +EFIAPI
> +XenBusUnregisterWatch (
> +  IN XENBUS_PROTOCOL  *This,
> +  IN VOID             *Token
> +  )
> +{
> +  XenStoreUnregisterWatch ((XENSTORE_WATCH *) Token);
> +}
> diff --git a/OvmfPkg/XenBusDxe/XenStore.h b/OvmfPkg/XenBusDxe/XenStore.h
> index 2902e3f..5d1a6b3 100644
> --- a/OvmfPkg/XenBusDxe/XenStore.h
> +++ b/OvmfPkg/XenBusDxe/XenStore.h
> @@ -289,4 +289,91 @@ XenStoreDeinit (
>    IN XENBUS_DEVICE *Dev
>    );
>  
> +
> +//
> +// XENBUS protocol
> +//
> +
> +VOID
> +EFIAPI
> +XenBusWaitForWatch (
> +  IN XENBUS_PROTOCOL *This,
> +  IN VOID *Token
> +  );
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreRead (
> +  IN  XENBUS_PROTOCOL       *This,
> +  IN  XENSTORE_TRANSACTION  Transaction,
> +  IN  CONST CHAR8           *Node,
> +  OUT VOID                  **Value
> +  );
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreBackendRead (
> +  IN  XENBUS_PROTOCOL       *This,
> +  IN  XENSTORE_TRANSACTION  Transaction,
> +  IN  CONST CHAR8           *Node,
> +  OUT VOID                  **Value
> +  );
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreRemove (
> +  IN XENBUS_PROTOCOL        *This,
> +  IN XENSTORE_TRANSACTION   Transaction,
> +  IN CONST CHAR8            *Node
> +  );
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreTransactionStart (
> +  IN  XENBUS_PROTOCOL       *This,
> +  OUT XENSTORE_TRANSACTION  *Transaction
> +  );
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreTransactionEnd (
> +  IN XENBUS_PROTOCOL        *This,
> +  IN XENSTORE_TRANSACTION   Transaction,
> +  IN BOOLEAN                Abort
> +  );
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusXenStoreSPrint (
> +  IN XENBUS_PROTOCOL        *This,
> +  IN XENSTORE_TRANSACTION   Transaction,
> +  IN CONST CHAR8            *DirectoryPath,
> +  IN CONST CHAR8            *Node,
> +  IN CONST CHAR8            *FormatString,
> +  ...
> +  );
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusRegisterWatch (
> +  IN  XENBUS_PROTOCOL *This,
> +  IN  CONST CHAR8     *Node,
> +  OUT VOID            **Token
> +  );
> +
> +XENSTORE_STATUS
> +EFIAPI
> +XenBusRegisterWatchBackend (
> +  IN  XENBUS_PROTOCOL *This,
> +  IN  CONST CHAR8     *Node,
> +  OUT VOID            **Token
> +  );
> +
> +VOID
> +EFIAPI
> +XenBusUnregisterWatch (
> +  IN XENBUS_PROTOCOL  *This,
> +  IN VOID             *Token
> +  );
> +
>  #endif /* _XEN_XENSTORE_XENSTOREVAR_H */
> -- 
> Anthony PERARD
> 
> 
> _______________________________________________
> Xen-devel mailing list
> Xen-devel@xxxxxxxxxxxxx
> http://lists.xen.org/xen-devel

_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

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