mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-18 02:38:56 +00:00
211815784c
When CONFIG_API is selected with DM_ETH this error is present: api/api_net.c: In function 'dev_enum_net': api/api_net.c:61:35: warning: initialization from incompatible pointer type struct eth_device *eth_current = eth_get_dev(); ^ api/api_net.c:68:39: error: dereferencing pointer to incomplete type memcpy(di->di_net.hwaddr, eth_current->enetaddr, 6); ^ Disable api_net functions when ETH_DM is selected. Signed-off-by: Chris Johns <chrisj@rtems.org> Signed-off-by: Michal Simek <michal.simek@xilinx.com>
117 lines
2 KiB
C
117 lines
2 KiB
C
/*
|
|
* (C) Copyright 2007 Semihalf
|
|
*
|
|
* Written by: Rafal Jaworowski <raj@semihalf.com>
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
#include <config.h>
|
|
#include <common.h>
|
|
#include <net.h>
|
|
#include <linux/types.h>
|
|
#include <api_public.h>
|
|
|
|
DECLARE_GLOBAL_DATA_PTR;
|
|
|
|
#define DEBUG
|
|
#undef DEBUG
|
|
|
|
#ifdef DEBUG
|
|
#define debugf(fmt, args...) do { printf("%s(): ", __func__); printf(fmt, ##args); } while (0)
|
|
#else
|
|
#define debugf(fmt, args...)
|
|
#endif
|
|
|
|
#define errf(fmt, args...) do { printf("ERROR @ %s(): ", __func__); printf(fmt, ##args); } while (0)
|
|
|
|
#if defined(CONFIG_CMD_NET) && !defined(CONFIG_DM_ETH)
|
|
|
|
static int dev_valid_net(void *cookie)
|
|
{
|
|
return ((void *)eth_get_dev() == cookie) ? 1 : 0;
|
|
}
|
|
|
|
int dev_open_net(void *cookie)
|
|
{
|
|
if (!dev_valid_net(cookie))
|
|
return API_ENODEV;
|
|
|
|
if (eth_init() < 0)
|
|
return API_EIO;
|
|
|
|
return 0;
|
|
}
|
|
|
|
int dev_close_net(void *cookie)
|
|
{
|
|
if (!dev_valid_net(cookie))
|
|
return API_ENODEV;
|
|
|
|
eth_halt();
|
|
return 0;
|
|
}
|
|
|
|
/*
|
|
* There can only be one active eth interface at a time - use what is
|
|
* currently set to eth_current
|
|
*/
|
|
int dev_enum_net(struct device_info *di)
|
|
{
|
|
struct eth_device *eth_current = eth_get_dev();
|
|
|
|
di->type = DEV_TYP_NET;
|
|
di->cookie = (void *)eth_current;
|
|
if (di->cookie == NULL)
|
|
return 0;
|
|
|
|
memcpy(di->di_net.hwaddr, eth_current->enetaddr, 6);
|
|
|
|
debugf("device found, returning cookie 0x%08x\n",
|
|
(u_int32_t)di->cookie);
|
|
|
|
return 1;
|
|
}
|
|
|
|
int dev_write_net(void *cookie, void *buf, int len)
|
|
{
|
|
/* XXX verify that cookie points to a valid net device??? */
|
|
|
|
return eth_send(buf, len);
|
|
}
|
|
|
|
int dev_read_net(void *cookie, void *buf, int len)
|
|
{
|
|
/* XXX verify that cookie points to a valid net device??? */
|
|
|
|
return eth_receive(buf, len);
|
|
}
|
|
|
|
#else
|
|
|
|
int dev_open_net(void *cookie)
|
|
{
|
|
return API_ENODEV;
|
|
}
|
|
|
|
int dev_close_net(void *cookie)
|
|
{
|
|
return API_ENODEV;
|
|
}
|
|
|
|
int dev_enum_net(struct device_info *di)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
int dev_write_net(void *cookie, void *buf, int len)
|
|
{
|
|
return API_ENODEV;
|
|
}
|
|
|
|
int dev_read_net(void *cookie, void *buf, int len)
|
|
{
|
|
return API_ENODEV;
|
|
}
|
|
|
|
#endif
|