mirror of https://github.com/ARMmbed/mbed-os.git
Made feature-emac changes to emac greentea tests default code
Removed flagging of the new/old code.pull/6847/head
parent
7aebda7a0f
commit
c1c69be10b
|
@ -15,7 +15,7 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
#if MBED_CONF_APP_TEST_WIFI || MBED_CONF_APP_TEST_ETHERNET
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
|
@ -15,7 +15,8 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
#if MBED_CONF_APP_TEST_WIFI || MBED_CONF_APP_TEST_ETHERNET
|
||||||
|
|
||||||
#ifndef EMAC_TEST_MEMORY_MANAGER_H
|
#ifndef EMAC_TEST_MEMORY_MANAGER_H
|
||||||
#define EMAC_TEST_MEMORY_MANAGER_H
|
#define EMAC_TEST_MEMORY_MANAGER_H
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
#if MBED_CONF_APP_TEST_WIFI || MBED_CONF_APP_TEST_ETHERNET
|
||||||
|
|
||||||
#include "unity.h"
|
#include "unity.h"
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
#if MBED_CONF_APP_TEST_WIFI || MBED_CONF_APP_TEST_ETHERNET
|
||||||
|
|
||||||
#ifndef EMAC_TEST_NETWORK_STACK_H
|
#ifndef EMAC_TEST_NETWORK_STACK_H
|
||||||
#define EMAC_TEST_NETWORK_STACK_H
|
#define EMAC_TEST_NETWORK_STACK_H
|
||||||
|
|
|
@ -23,20 +23,10 @@
|
||||||
|
|
||||||
#include "mbed.h"
|
#include "mbed.h"
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
|
|
||||||
#include "EMAC.h"
|
#include "EMAC.h"
|
||||||
#include "EMACMemoryManager.h"
|
#include "EMACMemoryManager.h"
|
||||||
#include "emac_TestMemoryManager.h"
|
#include "emac_TestMemoryManager.h"
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#include "lwip/opt.h" /* ETH_PAD_SIZE */
|
|
||||||
#include "emac_stack_mem.h"
|
|
||||||
#include "emac_api.h"
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "emac_tests.h"
|
#include "emac_tests.h"
|
||||||
#include "emac_ctp.h"
|
#include "emac_ctp.h"
|
||||||
|
|
||||||
|
@ -126,7 +116,6 @@ void emac_if_ctp_msg_build(int eth_frame_len, const unsigned char *dest_addr, co
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
int alloc_opt = 0;
|
int alloc_opt = 0;
|
||||||
int align = 0;
|
int align = 0;
|
||||||
if (options & CTP_OPT_NON_ALIGNED) {
|
if (options & CTP_OPT_NON_ALIGNED) {
|
||||||
|
@ -141,9 +130,6 @@ void emac_if_ctp_msg_build(int eth_frame_len, const unsigned char *dest_addr, co
|
||||||
// Default allocation is from pool
|
// Default allocation is from pool
|
||||||
buf = emac_m_mngr_get()->alloc_pool(eth_frame_len, align, alloc_opt);
|
buf = emac_m_mngr_get()->alloc_pool(eth_frame_len, align, alloc_opt);
|
||||||
}
|
}
|
||||||
#else
|
|
||||||
emac_stack_mem_chain_t *buf = emac_stack_mem_alloc(0, eth_frame_len + ETH_PAD_SIZE, 0);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (!buf) {
|
if (!buf) {
|
||||||
SET_ERROR_FLAGS(NO_FREE_MEM_BUF);
|
SET_ERROR_FLAGS(NO_FREE_MEM_BUF);
|
||||||
|
@ -161,14 +147,9 @@ void emac_if_ctp_msg_build(int eth_frame_len, const unsigned char *dest_addr, co
|
||||||
|
|
||||||
emac_if_memory_buffer_write(buf, eth_output_frame_data, true);
|
emac_if_memory_buffer_write(buf, eth_output_frame_data, true);
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
emac_if_check_memory(true);
|
emac_if_check_memory(true);
|
||||||
emac_if_get()->link_out(buf);
|
emac_if_get()->link_out(buf);
|
||||||
emac_if_check_memory(false);
|
emac_if_check_memory(false);
|
||||||
#else
|
|
||||||
emac_if_get()->ops.link_out(emac_if_get(), buf);
|
|
||||||
emac_stack_mem_free(0, buf);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -20,12 +20,7 @@
|
||||||
|
|
||||||
unsigned char *emac_if_get_hw_addr(void);
|
unsigned char *emac_if_get_hw_addr(void);
|
||||||
bool emac_if_init(void);
|
bool emac_if_init(void);
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
EMAC *emac_if_get(void);
|
EMAC *emac_if_get(void);
|
||||||
EmacTestMemoryManager *emac_m_mngr_get(void);
|
EmacTestMemoryManager *emac_m_mngr_get(void);
|
||||||
#else
|
|
||||||
emac_interface_t *emac_if_get(void);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* EMAC_INITIALIZE_H */
|
#endif /* EMAC_INITIALIZE_H */
|
||||||
|
|
|
@ -26,25 +26,14 @@
|
||||||
|
|
||||||
#include "mbed.h"
|
#include "mbed.h"
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
|
|
||||||
#include "EMAC.h"
|
#include "EMAC.h"
|
||||||
#include "EMACMemoryManager.h"
|
#include "EMACMemoryManager.h"
|
||||||
#include "emac_TestMemoryManager.h"
|
#include "emac_TestMemoryManager.h"
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#include "emac_api.h"
|
|
||||||
#include "emac_stack_mem.h"
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "emac_initialize.h"
|
#include "emac_initialize.h"
|
||||||
#include "emac_membuf.h"
|
#include "emac_membuf.h"
|
||||||
#include "emac_util.h"
|
#include "emac_util.h"
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
|
|
||||||
int emac_if_memory_buffer_read(void *buf, unsigned char *eth_frame)
|
int emac_if_memory_buffer_read(void *buf, unsigned char *eth_frame)
|
||||||
{
|
{
|
||||||
int eth_frame_index = 0;
|
int eth_frame_index = 0;
|
||||||
|
@ -91,58 +80,4 @@ void emac_if_memory_buffer_write(void *buf, unsigned char *eth_frame, bool write
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
int emac_if_memory_buffer_read(void *buf, unsigned char *eth_frame)
|
|
||||||
{
|
|
||||||
int eth_frame_index = 0;
|
|
||||||
int invalid_data_index = 0;
|
|
||||||
int index = ETH_PAD_SIZE;
|
|
||||||
|
|
||||||
for (emac_stack_mem_t *mem_p = emac_stack_mem_chain_dequeue(0, &buf); mem_p != NULL; mem_p = emac_stack_mem_chain_dequeue(0, &buf)) {
|
|
||||||
unsigned char *buf_payload = (unsigned char *) emac_stack_mem_ptr(0, mem_p);
|
|
||||||
int buf_payload_len = emac_stack_mem_len(0, mem_p);
|
|
||||||
|
|
||||||
for (; index < buf_payload_len; index++) {
|
|
||||||
if (eth_frame_index < ETH_FRAME_HEADER_LEN) {
|
|
||||||
eth_frame[eth_frame_index] = buf_payload[index];
|
|
||||||
} else {
|
|
||||||
if (buf_payload[index] != (uint8_t) eth_frame_index) {
|
|
||||||
invalid_data_index = eth_frame_index;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
eth_frame_index++;
|
|
||||||
}
|
|
||||||
index = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return invalid_data_index;
|
|
||||||
}
|
|
||||||
|
|
||||||
void emac_if_memory_buffer_write(void *buf, unsigned char *eth_frame, bool write_data)
|
|
||||||
{
|
|
||||||
int eth_frame_index = 0;
|
|
||||||
int index = ETH_PAD_SIZE;
|
|
||||||
|
|
||||||
for (emac_stack_mem_t *mem_p = emac_stack_mem_chain_dequeue(0, &buf); mem_p != NULL; mem_p = emac_stack_mem_chain_dequeue(0, &buf)) {
|
|
||||||
unsigned char *buf_payload = (unsigned char *) emac_stack_mem_ptr(0, mem_p);
|
|
||||||
int buf_payload_len = emac_stack_mem_len(0, mem_p);
|
|
||||||
|
|
||||||
for (; index < buf_payload_len; index++) {
|
|
||||||
if (eth_frame_index < ETH_FRAME_HEADER_LEN) {
|
|
||||||
buf_payload[index] = eth_frame[eth_frame_index];
|
|
||||||
} else if (write_data) {
|
|
||||||
buf_payload[index] = (char) eth_frame_index;
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
eth_frame_index++;
|
|
||||||
}
|
|
||||||
index = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -24,30 +24,20 @@
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_WIFI || MBED_CONF_APP_TEST_ETHERNET
|
#if MBED_CONF_APP_TEST_WIFI || MBED_CONF_APP_TEST_ETHERNET
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
|
|
||||||
#include "EthernetInterface.h"
|
#include "EthernetInterface.h"
|
||||||
#include "EMAC.h"
|
#include "EMAC.h"
|
||||||
#include "EMACMemoryManager.h"
|
#include "EMACMemoryManager.h"
|
||||||
#include "emac_TestMemoryManager.h"
|
#include "emac_TestMemoryManager.h"
|
||||||
#include "emac_TestNetworkStack.h"
|
#include "emac_TestNetworkStack.h"
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#include "inttypes.h"
|
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_WIFI
|
#if MBED_CONF_APP_TEST_WIFI
|
||||||
|
|
||||||
#ifdef TARGET_UBLOX_EVK_ODIN_W2
|
#ifdef TARGET_UBLOX_EVK_ODIN_W2
|
||||||
#include "wifi_emac_api.h"
|
|
||||||
#include "OdinWiFiInterface.h"
|
#include "OdinWiFiInterface.h"
|
||||||
#endif
|
#endif
|
||||||
#ifdef TARGET_REALTEK_RTL8195AM
|
#ifdef TARGET_REALTEK_RTL8195AM
|
||||||
#include "rtw_emac.h"
|
|
||||||
#include "RTWInterface.h"
|
#include "RTWInterface.h"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "emac_api.h"
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -59,17 +49,10 @@ using namespace utest::v1;
|
||||||
|
|
||||||
static unsigned char eth_mac_addr[ETH_MAC_ADDR_LEN];
|
static unsigned char eth_mac_addr[ETH_MAC_ADDR_LEN];
|
||||||
|
|
||||||
#if !MBED_CONF_APP_TEST_EMAC
|
|
||||||
static char emac_if_link_state_change_cb_data[] = "link_state_change_cb_data";
|
|
||||||
static char emac_if_link_input_cb_data[] = "link_input_cb_data";
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void test_emac_initialize()
|
void test_emac_initialize()
|
||||||
{
|
{
|
||||||
worker_loop_init();
|
worker_loop_init();
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_ETHERNET
|
#if MBED_CONF_APP_TEST_ETHERNET
|
||||||
|
|
||||||
static EthernetInterface *network_interface = new EthernetInterface;
|
static EthernetInterface *network_interface = new EthernetInterface;
|
||||||
|
@ -112,46 +95,6 @@ void test_emac_initialize()
|
||||||
network_interface->connect();
|
network_interface->connect();
|
||||||
|
|
||||||
worker_loop_link_up_wait();
|
worker_loop_link_up_wait();
|
||||||
#else
|
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_WIFI
|
|
||||||
static WiFiInterface *wifi;
|
|
||||||
|
|
||||||
#ifdef TARGET_UBLOX_EVK_ODIN_W2
|
|
||||||
wifi = new OdinWiFiInterface;
|
|
||||||
#endif
|
|
||||||
#ifdef TARGET_REALTEK_RTL8195AM
|
|
||||||
wifi = new RTWInterface;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if MBED_CONF_APP_WIFI_SCAN
|
|
||||||
WiFiAccessPoint ap[30];
|
|
||||||
|
|
||||||
int size = wifi->scan(ap, 30);
|
|
||||||
|
|
||||||
for (int i=0; i<size; i++) {
|
|
||||||
const char *ssid = ap[i].get_ssid();
|
|
||||||
nsapi_security_t security = ap[i].get_security();
|
|
||||||
int8_t rssi = ap[i].get_rssi();
|
|
||||||
char ch = ap[i].get_channel();
|
|
||||||
|
|
||||||
printf("BS %i\r\n", i);
|
|
||||||
printf("ssid %s\r\n", ssid);
|
|
||||||
printf("security %i\r\n", security);
|
|
||||||
printf("rssi %i\r\n", rssi);
|
|
||||||
printf("ch %i\r\n\r\n", ch);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
wifi->set_credentials(MBED_CONF_APP_WIFI_SSID, MBED_CONF_APP_WIFI_PASSWORD, MBED_CONF_APP_WIFI_SECURITY);
|
|
||||||
wifi->connect();
|
|
||||||
|
|
||||||
const char *ip_addr = wifi->get_ip_address();
|
|
||||||
printf("connected IP %s\r\n\r\n", ip_addr);
|
|
||||||
|
|
||||||
TEST_ASSERT(emac_if_init());
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned char *emac_if_get_hw_addr(void)
|
unsigned char *emac_if_get_hw_addr(void)
|
||||||
|
@ -159,7 +102,6 @@ unsigned char *emac_if_get_hw_addr(void)
|
||||||
return ð_mac_addr[0];
|
return ð_mac_addr[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
EMAC *emac_if_get(void)
|
EMAC *emac_if_get(void)
|
||||||
{
|
{
|
||||||
return &EMAC::get_default_instance();
|
return &EMAC::get_default_instance();
|
||||||
|
@ -170,26 +112,8 @@ EmacTestMemoryManager *emac_m_mngr_get(void)
|
||||||
return &EmacTestMemoryManager::get_instance();
|
return &EmacTestMemoryManager::get_instance();
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
emac_interface_t *emac_if_get(void)
|
|
||||||
{
|
|
||||||
#if MBED_CONF_APP_TEST_WIFI
|
|
||||||
#ifdef TARGET_UBLOX_EVK_ODIN_W2
|
|
||||||
return wifi_emac_get_interface();
|
|
||||||
#endif
|
|
||||||
#ifdef TARGET_REALTEK_RTL8195AM
|
|
||||||
return wlan_emac_init_interface();
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
return 0;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
bool emac_if_init(void)
|
bool emac_if_init(void)
|
||||||
{
|
{
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
static EMAC *emac = &EMAC::get_default_instance();
|
static EMAC *emac = &EMAC::get_default_instance();
|
||||||
static EmacTestMemoryManager *memory_manager = &EmacTestMemoryManager::get_instance();
|
static EmacTestMemoryManager *memory_manager = &EmacTestMemoryManager::get_instance();
|
||||||
emac->set_memory_manager(*memory_manager);
|
emac->set_memory_manager(*memory_manager);
|
||||||
|
@ -221,34 +145,6 @@ bool emac_if_init(void)
|
||||||
printf("emac if name %s\r\n\r\n", hw_name);
|
printf("emac if name %s\r\n\r\n", hw_name);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
#else
|
|
||||||
emac_interface_t *emac_if = emac_if_get();
|
|
||||||
|
|
||||||
emac_if->ops.set_link_input_cb(emac_if, emac_if_link_input_cb, emac_if_link_input_cb_data);
|
|
||||||
emac_if->ops.set_link_state_cb(emac_if, emac_if_link_state_change_cb, emac_if_link_state_change_cb_data);
|
|
||||||
|
|
||||||
int hwaddr_len = emac_if->ops.get_hwaddr_size(emac_if);
|
|
||||||
printf("emac hwaddr length %i\r\n\r\n", hwaddr_len);
|
|
||||||
|
|
||||||
if (hwaddr_len == 6) {
|
|
||||||
emac_if->ops.get_hwaddr(emac_if, eth_mac_addr);
|
|
||||||
printf("emac hwaddr %x:%x:%x:%x:%x:%x\r\n\r\n", eth_mac_addr[0],eth_mac_addr[1],eth_mac_addr[2],eth_mac_addr[3],eth_mac_addr[4],eth_mac_addr[5]);
|
|
||||||
}
|
|
||||||
|
|
||||||
int mtu_size = emac_if->ops.get_mtu_size(emac_if);
|
|
||||||
printf("emac mtu %i\r\n\r\n", mtu_size);
|
|
||||||
emac_if_set_mtu_size(mtu_size);
|
|
||||||
|
|
||||||
char hw_name[11];
|
|
||||||
emac_if->ops.get_ifname(emac_if, hw_name, 10);
|
|
||||||
printf("emac if name %s\r\n\r\n", hw_name);
|
|
||||||
|
|
||||||
if (!emac_if->ops.power_up(emac_if)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -24,23 +24,10 @@
|
||||||
|
|
||||||
#include "mbed.h"
|
#include "mbed.h"
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
|
|
||||||
#include "EMAC.h"
|
#include "EMAC.h"
|
||||||
#include "EMACMemoryManager.h"
|
#include "EMACMemoryManager.h"
|
||||||
#include "emac_TestMemoryManager.h"
|
#include "emac_TestMemoryManager.h"
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
extern "C" { // netif input
|
|
||||||
#include "tcpip.h"
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "emac_api.h"
|
|
||||||
#include "emac_stack_mem.h"
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "emac_tests.h"
|
#include "emac_tests.h"
|
||||||
#include "emac_initialize.h"
|
#include "emac_initialize.h"
|
||||||
#include "emac_util.h"
|
#include "emac_util.h"
|
||||||
|
@ -49,7 +36,6 @@ extern "C" { // netif input
|
||||||
|
|
||||||
using namespace utest::v1;
|
using namespace utest::v1;
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int length;
|
int length;
|
||||||
int receipt_number;
|
int receipt_number;
|
||||||
|
@ -368,16 +354,12 @@ void emac_if_trace_to_ascii_hex_dump(const char *prefix, int len, unsigned char
|
||||||
|
|
||||||
void emac_if_set_all_multicast(bool all)
|
void emac_if_set_all_multicast(bool all)
|
||||||
{
|
{
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
emac_if_get()->set_all_multicast(all);
|
emac_if_get()->set_all_multicast(all);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void emac_if_add_multicast_group(uint8_t *address)
|
void emac_if_add_multicast_group(uint8_t *address)
|
||||||
{
|
{
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
emac_if_get()->add_multicast_group(address);
|
emac_if_get()->add_multicast_group(address);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void emac_if_set_output_memory(bool memory)
|
void emac_if_set_output_memory(bool memory)
|
||||||
|
@ -403,21 +385,15 @@ void emac_if_check_memory(bool output)
|
||||||
|
|
||||||
void emac_if_set_memory(bool memory)
|
void emac_if_set_memory(bool memory)
|
||||||
{
|
{
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
static bool memory_value = true;
|
static bool memory_value = true;
|
||||||
if (memory_value != memory ) {
|
if (memory_value != memory ) {
|
||||||
memory_value = memory;
|
memory_value = memory;
|
||||||
EmacTestMemoryManager *mem_mngr = emac_m_mngr_get();
|
EmacTestMemoryManager *mem_mngr = emac_m_mngr_get();
|
||||||
mem_mngr->set_memory_available(memory);
|
mem_mngr->set_memory_available(memory);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
void emac_if_link_state_change_cb(bool up)
|
void emac_if_link_state_change_cb(bool up)
|
||||||
#else
|
|
||||||
void emac_if_link_state_change_cb(void *data, bool up)
|
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
if (up) {
|
if (up) {
|
||||||
worker_loop_event.post(LINK_UP);
|
worker_loop_event.post(LINK_UP);
|
||||||
|
@ -426,22 +402,14 @@ void emac_if_link_state_change_cb(void *data, bool up)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
void emac_if_link_input_cb(void *buf)
|
void emac_if_link_input_cb(void *buf)
|
||||||
#else
|
|
||||||
void emac_if_link_input_cb(void *data, void *buf)
|
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
link_input_event.post(buf);
|
link_input_event.post(buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void link_input_event_cb(void *buf)
|
static void link_input_event_cb(void *buf)
|
||||||
{
|
{
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
int length = emac_m_mngr_get()->get_total_len(buf);
|
int length = emac_m_mngr_get()->get_total_len(buf);
|
||||||
#else
|
|
||||||
int length = emac_stack_mem_len(0, buf);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (length >= ETH_FRAME_HEADER_LEN) {
|
if (length >= ETH_FRAME_HEADER_LEN) {
|
||||||
// Ethernet input frame
|
// Ethernet input frame
|
||||||
|
@ -472,53 +440,24 @@ static void link_input_event_cb(void *buf)
|
||||||
// Echoes only if configured as echo server
|
// Echoes only if configured as echo server
|
||||||
} else if (function == CTP_FORWARD) {
|
} else if (function == CTP_FORWARD) {
|
||||||
emac_if_memory_buffer_write(buf, eth_output_frame_data, false);
|
emac_if_memory_buffer_write(buf, eth_output_frame_data, false);
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
emac_if_get()->link_out(buf);
|
emac_if_get()->link_out(buf);
|
||||||
buf = 0;
|
buf = 0;
|
||||||
#else
|
|
||||||
emac_if_get()->ops.link_out(emac_if_get(), buf);
|
|
||||||
#endif
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
emac_if_add_echo_server_addr(ð_input_frame_data[6]);
|
emac_if_add_echo_server_addr(ð_input_frame_data[6]);
|
||||||
|
|
||||||
#if !MBED_CONF_APP_TEST_EMAC
|
|
||||||
emac_stack_mem_free(0, buf);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (trace_level & TRACE_ETH_FRAMES) {
|
if (trace_level & TRACE_ETH_FRAMES) {
|
||||||
printf("INP> LEN %i\r\n\r\n", length);
|
printf("INP> LEN %i\r\n\r\n", length);
|
||||||
const char trace_type[] = "INP>";
|
const char trace_type[] = "INP>";
|
||||||
emac_if_trace_to_ascii_hex_dump(trace_type, ETH_FRAME_HEADER_LEN, eth_input_frame_data);
|
emac_if_trace_to_ascii_hex_dump(trace_type, ETH_FRAME_HEADER_LEN, eth_input_frame_data);
|
||||||
}
|
}
|
||||||
#if !MBED_CONF_APP_TEST_EMAC
|
|
||||||
return;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
if (buf) {
|
if (buf) {
|
||||||
emac_m_mngr_get()->free(buf);
|
emac_m_mngr_get()->free(buf);
|
||||||
}
|
}
|
||||||
#else
|
|
||||||
// Forward other than CTP frames to lwip
|
|
||||||
struct netif *netif;
|
|
||||||
|
|
||||||
/* loop through netif's */
|
|
||||||
netif = netif_list;
|
|
||||||
if (netif != NULL) {
|
|
||||||
struct pbuf *p = (struct pbuf *)buf;
|
|
||||||
|
|
||||||
/* pass all packets to ethernet_input, which decides what packets it supports */
|
|
||||||
if (netif->input(p, netif) != ERR_OK) {
|
|
||||||
emac_stack_mem_free(0, buf);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
emac_stack_mem_free(0, buf);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned char thread_stack[2048];
|
static unsigned char thread_stack[2048];
|
||||||
|
|
|
@ -108,13 +108,8 @@ unsigned char *emac_if_get_own_addr(void);
|
||||||
int emac_if_get_mtu_size();
|
int emac_if_get_mtu_size();
|
||||||
void emac_if_set_mtu_size(int mtu_size);
|
void emac_if_set_mtu_size(int mtu_size);
|
||||||
|
|
||||||
#if MBED_CONF_APP_TEST_EMAC
|
|
||||||
extern void emac_if_link_input_cb(void *buf);
|
extern void emac_if_link_input_cb(void *buf);
|
||||||
extern void emac_if_link_state_change_cb(bool up);
|
extern void emac_if_link_state_change_cb(bool up);
|
||||||
#else
|
|
||||||
extern void emac_if_link_input_cb(void *data, void *buf);
|
|
||||||
extern void emac_if_link_state_change_cb(void *data, bool up);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void emac_if_set_all_multicast(bool all);
|
void emac_if_set_all_multicast(bool all);
|
||||||
void emac_if_add_multicast_group(uint8_t *address);
|
void emac_if_add_multicast_group(uint8_t *address);
|
||||||
|
|
|
@ -15,8 +15,7 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if !defined(MBED_CONF_APP_TEST_EMAC) || \
|
#if !defined(MBED_CONF_APP_TEST_WIFI) || \
|
||||||
!defined(MBED_CONF_APP_TEST_WIFI) || \
|
|
||||||
!defined(MBED_CONF_APP_TEST_ETHERNET) || \
|
!defined(MBED_CONF_APP_TEST_ETHERNET) || \
|
||||||
!defined(MBED_CONF_APP_ECHO_SERVER) || \
|
!defined(MBED_CONF_APP_ECHO_SERVER) || \
|
||||||
!defined(MBED_CONF_APP_WIFI_SCAN) || \
|
!defined(MBED_CONF_APP_WIFI_SCAN) || \
|
||||||
|
|
|
@ -1,9 +1,5 @@
|
||||||
{
|
{
|
||||||
"config": {
|
"config": {
|
||||||
"test-emac": {
|
|
||||||
"help": "Test feature-emac version of the emac",
|
|
||||||
"value": 1
|
|
||||||
},
|
|
||||||
"test-ethernet": {
|
"test-ethernet": {
|
||||||
"help": "Enable ethernet testing",
|
"help": "Enable ethernet testing",
|
||||||
"value": 1
|
"value": 1
|
||||||
|
|
Loading…
Reference in New Issue