aboutsummaryrefslogtreecommitdiffstats
path: root/os/hal/include/hal_objects.h
blob: 59c3884da4b19399e2cc7e51e86173c4c4823784 (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
84
85
86
/*
    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio

    Licensed under the Apache License, Version 2.0 (the "License");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at

        http://www.apache.org/licenses/LICENSE-2.0

    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an "AS IS" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.
*/

/**
 * @file    hal_objects.h
 * @brief   Base object.
 * @details This header defines a base object that is the root for the
 *          inheritance system.
 *
 * @addtogroup HAL_BASE_OBJECT
 * @details HAL uses concepts of Object Oriented Programming even if it
 *          is written in C. Things like simple inheritance, multiple
 *          inheritance and interfaces are used through the system.
 *          This module defines a "base object" that is the ancestor of
 *          all classes in the system.
 * @{
 */

#ifndef HAL_OBJECTS_H
#define HAL_OBJECTS_H

/**
 * @brief   @p BaseObject specific methods.
 * @note    This object defines no methods.
 */
#define _base_object_methods                                                \
  /* Instance offset, used for multiple inheritance, normally zero. It
     represents the offset between the current object and the container
     object*/                                                               \
  size_t instance_offset;

/**
 * @brief   @p BaseObject specific data.
 * @note    This object defines no data.
 */
#define _base_object_data

/**
 * @brief   @p BaseObject virtual methods table.
 */
struct BaseObjectVMT {
  _base_object_methods
};

/**
 * @brief   Base stream class.
 * @details This class represents a generic blocking unbuffered sequential
 *          data stream.
 */
typedef struct {
  /** @brief Virtual Methods Table.*/
  const struct BaseObjectVMT *vmt;
  _base_object_data
} BaseObject;

/**
 * @name    Macro Functions (BaseObject)
 * @{
 */
/**
 * @brief   Returns the instance pointer starting from an interface pointer.
 *
 * @param[in] type  the type of the instance pointer, it is used for casting
 * @param[in] ip    the interface pointer
 * @return          A pointer to the object implementing the interface
 */
#define objGetInstance(type, ip)                                            \
  (type)(((size_t)(ip)) - (ip)->vmt->instance_offset)
/** @} */

#endif /* HAL_OBJECTS_H */

/** @} */
CPCLIENT_APP_H_ /* Includes: */ #include <stdio.h> #include <uip.h> #include "../Webserver.h" /* Macros: */ /** UDP listen port for a BOOTP server. */ #define DHCPC_SERVER_PORT 67 /** UDP listen port for a BOOTP client. */ #define DHCPC_CLIENT_PORT 68 /** BOOTP message type for a BOOTP REQUEST message. */ #define DHCP_OP_BOOTREQUEST 0x01 /** BOOTP message type for a BOOTP REPLY message. */ #define DHCP_OP_BOOTREPLY 0x02 /** BOOTP flag for a BOOTP broadcast message. */ #define BOOTP_BROADCAST 0x8000 /** Magic DHCP cookie for a BOOTP message to identify it as a DHCP message. */ #define DHCP_MAGIC_COOKIE 0x63538263 /** Unique transaction ID used to identify DHCP responses to the client. */ #define DHCP_TRANSACTION_ID 0x13245466 /** DHCP message type for a DISCOVER message. */ #define DHCP_DISCOVER 1 /** DHCP message type for an OFFER message. */ #define DHCP_OFFER 2 /** DHCP message type for a REQUEST message. */ #define DHCP_REQUEST 3 /** DHCP message type for a DECLINE message. */ #define DHCP_DECLINE 4 /** DHCP message type for an ACK message. */ #define DHCP_ACK 5 /** DHCP message type for a NAK message. */ #define DHCP_NAK 6 /** DHCP message type for a RELEASE message. */ #define DHCP_RELEASE 7 /** DHCP medium type for standard Ethernet. */ #define DHCP_HTYPE_ETHERNET 1 /** DHCP message option for the network subnet mask. */ #define DHCP_OPTION_SUBNET_MASK 1 /** DHCP message option for the network gateway IP. */ #define DHCP_OPTION_ROUTER 3 /** DHCP message option for the network DNS server. */ #define DHCP_OPTION_DNS_SERVER 6 /** DHCP message option for the requested client IP address. */ #define DHCP_OPTION_REQ_IPADDR 50 /** DHCP message option for the IP address lease time. */ #define DHCP_OPTION_LEASE_TIME 51 /** DHCP message option for the DHCP message type. */ #define DHCP_OPTION_MSG_TYPE 53 /** DHCP message option for the DHCP server IP. */ #define DHCP_OPTION_SERVER_ID 54 /** DHCP message option for the list of required options from the server. */ #define DHCP_OPTION_REQ_LIST 55 /** DHCP message option for the options list terminator. */ #define DHCP_OPTION_END 255 /* Type Defines: */ /** Type define for a DHCP packet inside an Ethernet frame. */ typedef struct { uint8_t Operation; /**< DHCP operation, either DHCP_OP_BOOTREQUEST or DHCP_OP_BOOTREPLY */ uint8_t HardwareType; /**< Hardware carrier type constant */ uint8_t HardwareAddressLength; /**< Length in bytes of a hardware (MAC) address on the network */ uint8_t Hops; /**< Number of hops required to reach the server, unused */ uint32_t TransactionID; /**< Unique ID of the DHCP packet, for positive matching between sent and received packets */ uint16_t ElapsedSeconds; /**< Elapsed seconds since the request was made */ uint16_t Flags; /**< BOOTP packet flags */ uip_ipaddr_t ClientIP; /**< Client IP address, if already leased an IP */ uip_ipaddr_t YourIP; /**< Client IP address */ uip_ipaddr_t NextServerIP; /**< Legacy BOOTP protocol field, unused for DHCP */ uip_ipaddr_t RelayAgentIP; /**< Legacy BOOTP protocol field, unused for DHCP */ uint8_t ClientHardwareAddress[16]; /**< Hardware (MAC) address of the client making a request to the DHCP server */ uint8_t ServerHostnameString[64]; /**< Legacy BOOTP protocol field, unused for DHCP */ uint8_t BootFileName[128]; /**< Legacy BOOTP protocol field, unused for DHCP */ uint32_t Cookie; /**< Magic BOOTP protocol cookie to indicate a valid packet */ uint8_t Options[]; /**< DHCP message options */ } DHCP_Header_t; /* Enums: */ /** States for each DHCP connection to a DHCP client. */ enum DHCP_States_t { DHCP_STATE_SendDiscover, /**< Send DISCOVER packet to retrieve DHCP lease offers */ DHCP_STATE_WaitForOffer, /**< Waiting for OFFER packet giving available DHCP leases */ DHCP_STATE_SendRequest, /**< Send REQUEST packet to request a DHCP lease */ DHCP_STATE_WaitForACK, /**< Wait for ACK packet to complete the DHCP lease */ DHCP_STATE_AddressLeased, /**< DHCP address has been leased from a DHCP server */ }; /* Function Prototypes: */ void DHCPClientApp_Init(void); void DHCPClientApp_Callback(void); #if defined(INCLUDE_FROM_DHCPCLIENTAPP_C) static uint16_t DHCPClientApp_FillDHCPHeader(DHCP_Header_t* const DHCPHeader, const uint8_t DHCPMessageType, uip_udp_appstate_t* const AppState); static uint8_t DHCPClientApp_SetOption(uint8_t* DHCPOptionList, const uint8_t Option, const uint8_t DataLen, void* const OptionData); static bool DHCPClientApp_GetOption(const uint8_t* DHCPOptionList, const uint8_t Option, void* const Destination); #endif #endif