mirror of
https://git.codelinaro.org/clo/qsdk/oss/boot/u-boot-2016.git
synced 2025-12-10 07:44:53 +01:00
net: Use packed structures for networking
With latest GCC 4 byte aligned instructions are getting generated for 2 byte aligned data. This is due to the option '-fstore-merging' enabled by default for '-O2' This is causing data abort if data cache is disabled. Signed-off-by: Sivaprakash Murugesan <sivaprak@codeaurora.org> Change-Id: Idaac94fcc8e5c61f0ea720ed0c10e908d3688c61
This commit is contained in:
parent
ac3c252cf1
commit
7767cd056e
5 changed files with 11 additions and 11 deletions
|
|
@ -278,7 +278,7 @@ struct ethernet_hdr {
|
||||||
u8 et_dest[6]; /* Destination node */
|
u8 et_dest[6]; /* Destination node */
|
||||||
u8 et_src[6]; /* Source node */
|
u8 et_src[6]; /* Source node */
|
||||||
u16 et_protlen; /* Protocol or length */
|
u16 et_protlen; /* Protocol or length */
|
||||||
};
|
} __attribute__((packed));
|
||||||
|
|
||||||
/* Ethernet header size */
|
/* Ethernet header size */
|
||||||
#define ETHER_HDR_SIZE (sizeof(struct ethernet_hdr))
|
#define ETHER_HDR_SIZE (sizeof(struct ethernet_hdr))
|
||||||
|
|
@ -296,7 +296,7 @@ struct e802_hdr {
|
||||||
u8 et_snap2;
|
u8 et_snap2;
|
||||||
u8 et_snap3;
|
u8 et_snap3;
|
||||||
u16 et_prot; /* 802 protocol */
|
u16 et_prot; /* 802 protocol */
|
||||||
};
|
} __attribute__((packed));
|
||||||
|
|
||||||
/* 802 + SNAP + ethernet header size */
|
/* 802 + SNAP + ethernet header size */
|
||||||
#define E802_HDR_SIZE (sizeof(struct e802_hdr))
|
#define E802_HDR_SIZE (sizeof(struct e802_hdr))
|
||||||
|
|
@ -310,7 +310,7 @@ struct vlan_ethernet_hdr {
|
||||||
u16 vet_vlan_type; /* PROT_VLAN */
|
u16 vet_vlan_type; /* PROT_VLAN */
|
||||||
u16 vet_tag; /* TAG of VLAN */
|
u16 vet_tag; /* TAG of VLAN */
|
||||||
u16 vet_type; /* protocol type */
|
u16 vet_type; /* protocol type */
|
||||||
};
|
} __attribute__((packed));
|
||||||
|
|
||||||
/* VLAN Ethernet header size */
|
/* VLAN Ethernet header size */
|
||||||
#define VLAN_ETHER_HDR_SIZE (sizeof(struct vlan_ethernet_hdr))
|
#define VLAN_ETHER_HDR_SIZE (sizeof(struct vlan_ethernet_hdr))
|
||||||
|
|
@ -337,7 +337,7 @@ struct ip_hdr {
|
||||||
u16 ip_sum; /* checksum */
|
u16 ip_sum; /* checksum */
|
||||||
struct in_addr ip_src; /* Source IP address */
|
struct in_addr ip_src; /* Source IP address */
|
||||||
struct in_addr ip_dst; /* Destination IP address */
|
struct in_addr ip_dst; /* Destination IP address */
|
||||||
};
|
} __attribute__((packed));
|
||||||
|
|
||||||
#define IP_OFFS 0x1fff /* ip offset *= 8 */
|
#define IP_OFFS 0x1fff /* ip offset *= 8 */
|
||||||
#define IP_FLAGS 0xe000 /* first 3 bits */
|
#define IP_FLAGS 0xe000 /* first 3 bits */
|
||||||
|
|
@ -365,7 +365,7 @@ struct ip_udp_hdr {
|
||||||
u16 udp_dst; /* UDP destination port */
|
u16 udp_dst; /* UDP destination port */
|
||||||
u16 udp_len; /* Length of UDP packet */
|
u16 udp_len; /* Length of UDP packet */
|
||||||
u16 udp_xsum; /* Checksum */
|
u16 udp_xsum; /* Checksum */
|
||||||
};
|
} __attribute__((packed));
|
||||||
|
|
||||||
#define IP_UDP_HDR_SIZE (sizeof(struct ip_udp_hdr))
|
#define IP_UDP_HDR_SIZE (sizeof(struct ip_udp_hdr))
|
||||||
#define UDP_HDR_SIZE (IP_UDP_HDR_SIZE - IP_HDR_SIZE)
|
#define UDP_HDR_SIZE (IP_UDP_HDR_SIZE - IP_HDR_SIZE)
|
||||||
|
|
@ -404,7 +404,7 @@ struct arp_hdr {
|
||||||
u8 ar_tha[]; /* Target hardware address */
|
u8 ar_tha[]; /* Target hardware address */
|
||||||
u8 ar_tpa[]; /* Target protocol address */
|
u8 ar_tpa[]; /* Target protocol address */
|
||||||
#endif /* 0 */
|
#endif /* 0 */
|
||||||
};
|
} __attribute__((packed));
|
||||||
|
|
||||||
#define ARP_HDR_SIZE (8+20) /* Size assuming ethernet */
|
#define ARP_HDR_SIZE (8+20) /* Size assuming ethernet */
|
||||||
|
|
||||||
|
|
@ -439,7 +439,7 @@ struct icmp_hdr {
|
||||||
} frag;
|
} frag;
|
||||||
u8 data[0];
|
u8 data[0];
|
||||||
} un;
|
} un;
|
||||||
};
|
} __attribute__((packed));
|
||||||
|
|
||||||
#define ICMP_HDR_SIZE (sizeof(struct icmp_hdr))
|
#define ICMP_HDR_SIZE (sizeof(struct icmp_hdr))
|
||||||
#define IP_ICMP_HDR_SIZE (IP_HDR_SIZE + ICMP_HDR_SIZE)
|
#define IP_ICMP_HDR_SIZE (IP_HDR_SIZE + ICMP_HDR_SIZE)
|
||||||
|
|
|
||||||
|
|
@ -49,7 +49,7 @@ struct bootp_hdr {
|
||||||
char bp_sname[64]; /* Server host name */
|
char bp_sname[64]; /* Server host name */
|
||||||
char bp_file[128]; /* Boot file name */
|
char bp_file[128]; /* Boot file name */
|
||||||
char bp_vend[OPT_FIELD_SIZE]; /* Vendor information */
|
char bp_vend[OPT_FIELD_SIZE]; /* Vendor information */
|
||||||
};
|
} __attribute__((packed));
|
||||||
|
|
||||||
#define BOOTP_HDR_SIZE sizeof(struct bootp_hdr)
|
#define BOOTP_HDR_SIZE sizeof(struct bootp_hdr)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -29,7 +29,7 @@ struct header {
|
||||||
uint16_t nauth; /* Authority PRs */
|
uint16_t nauth; /* Authority PRs */
|
||||||
uint16_t nother; /* Other PRs */
|
uint16_t nother; /* Other PRs */
|
||||||
unsigned char data[1]; /* Data, variable length */
|
unsigned char data[1]; /* Data, variable length */
|
||||||
};
|
} __attribute__((packed));
|
||||||
|
|
||||||
void dns_start(void); /* Begin DNS */
|
void dns_start(void); /* Begin DNS */
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -68,7 +68,7 @@ struct rpc_t {
|
||||||
uint32_t data[19];
|
uint32_t data[19];
|
||||||
} reply;
|
} reply;
|
||||||
} u;
|
} u;
|
||||||
};
|
} __attribute__((packed));
|
||||||
void nfs_start(void); /* Begin NFS */
|
void nfs_start(void); /* Begin NFS */
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -51,7 +51,7 @@ struct sntp_pkt_t {
|
||||||
unsigned long long originate_timestamp;
|
unsigned long long originate_timestamp;
|
||||||
unsigned long long receive_timestamp;
|
unsigned long long receive_timestamp;
|
||||||
unsigned long long transmit_timestamp;
|
unsigned long long transmit_timestamp;
|
||||||
};
|
} __attribute__((packed));
|
||||||
|
|
||||||
void sntp_start(void); /* Begin SNTP */
|
void sntp_start(void); /* Begin SNTP */
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue