summaryrefslogtreecommitdiff
path: root/MdeModulePkg/Universal/Network/Ip4Dxe/Ip4Option.h
blob: 546bf8ca6d0c932ede9effcb11e931a5a40151b3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/** @file

Copyright (c) 2005 - 2006, Intel Corporation
All rights reserved. This program and the accompanying materials
are licensed and made available under the terms and conditions of the BSD License
which accompanies this distribution.  The full text of the license may be found at
http://opensource.org/licenses/bsd-license.php

THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.


Module Name:

  Ip4Option.h

Abstract:

  IP4 option support routines.


**/

#ifndef __EFI_IP4_OPTION_H__
#define __EFI_IP4_OPTION_H__

typedef enum {
  IP4_OPTION_EOP       = 0,
  IP4_OPTION_NOP       = 1,
  IP4_OPTION_LSRR      = 131,  // Loss source and record routing,   10000011
  IP4_OPTION_SSRR      = 137,  // Strict source and record routing, 10001001
  IP4_OPTION_RR        = 7,    // Record routing, 00000111

  IP4_OPTION_COPY_MASK = 0x80
} IP4_OPTION_ENUM_TYPES;

/**
  Validate the IP4 option format for both the packets we received
  and will transmit. It will compute the ICMP error message fields
  if the option is mal-formated. But this information isn't used.

  @param  Option                The first byte of the option
  @param  OptionLen             The length of the whole option
  @param  Rcvd                  The option is from the packet we received if TRUE,
                                otherwise the option we wants to transmit.

  @retval TRUE     The option is properly formatted
  @retval FALSE    The option is mal-formated

**/
BOOLEAN
Ip4OptionIsValid (
  IN UINT8                  *Option,
  IN UINT32                 OptionLen,
  IN BOOLEAN                Rcvd
  );

/**
  Copy the option from the original option to buffer. It
  handles the details such as:
  1. whether copy the single IP4 option to the first/non-first
     fragments.
  2. Pad the options copied over to aligned to 4 bytes.

  @param  Option                The original option to copy from
  @param  OptionLen             The length of the original option
  @param  FirstFragment         Whether it is the first fragment
  @param  Buf                   The buffer to copy options to. NULL 
  @param  BufLen                The length of the buffer

  @retval EFI_SUCCESS           The options are copied over
  @retval EFI_BUFFER_TOO_SMALL  Buf is NULL or BufLen provided is too small.

**/
EFI_STATUS
Ip4CopyOption (
  IN     UINT8              *Option,
  IN     UINT32             OptionLen,
  IN     BOOLEAN            FirstFragment,
  IN OUT UINT8              *Buf,           OPTIONAL
  IN OUT UINT32             *BufLen
  );
#endif