3 Implementation of the SNP.Start() function and its private helpers if any.
5 Copyright (C) 2013, Red Hat, Inc.
6 Copyright (c) 2006 - 2010, Intel Corporation. All rights reserved.<BR>
8 This program and the accompanying materials are licensed and made available
9 under the terms and conditions of the BSD License which accompanies this
10 distribution. The full text of the license may be found at
11 http://opensource.org/licenses/bsd-license.php
13 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT
14 WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
18 #include <Library/UefiBootServicesTableLib.h>
20 #include "VirtioNet.h"
23 Changes the state of a network interface from "stopped" to "started".
25 @param This Protocol instance pointer.
27 @retval EFI_SUCCESS The network interface was started.
28 @retval EFI_ALREADY_STARTED The network interface is already in the started
30 @retval EFI_INVALID_PARAMETER One or more of the parameters has an
32 @retval EFI_DEVICE_ERROR The command could not be sent to the network
34 @retval EFI_UNSUPPORTED This function is not supported by the network
41 IN EFI_SIMPLE_NETWORK_PROTOCOL
*This
49 return EFI_INVALID_PARAMETER
;
52 Dev
= VIRTIO_NET_FROM_SNP (This
);
53 OldTpl
= gBS
->RaiseTPL (TPL_CALLBACK
);
54 if (Dev
->Snm
.State
!= EfiSimpleNetworkStopped
) {
55 Status
= EFI_ALREADY_STARTED
;
58 Dev
->Snm
.State
= EfiSimpleNetworkStarted
;
62 gBS
->RestoreTPL (OldTpl
);