hc
2024-03-22 f63cd4c03ea42695d5f9b0e1798edd196923aae6
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
/*
 * TI DaVinci EMAC platform support
 *
 * Author: Kevin Hilman, Deep Root Systems, LLC
 *
 * 2007 (c) Deep Root Systems, LLC. This file is licensed under
 * the terms of the GNU General Public License version 2. This program
 * is licensed "as is" without any warranty of any kind, whether express
 * or implied.
 */
#ifndef _LINUX_DAVINCI_EMAC_H
#define _LINUX_DAVINCI_EMAC_H
 
#include <linux/if_ether.h>
#include <linux/nvmem-consumer.h>
 
struct mdio_platform_data {
   unsigned long        bus_freq;
};
 
struct emac_platform_data {
   char mac_addr[ETH_ALEN];
   u32 ctrl_reg_offset;
   u32 ctrl_mod_reg_offset;
   u32 ctrl_ram_offset;
   u32 hw_ram_addr;
   u32 ctrl_ram_size;
 
   /*
    * phy_id can be one of the following:
    *   - NULL        : use the first phy on the bus,
    *   - ""        : force to 100/full, no mdio control
    *   - "<bus>:<addr>"    : use the specified bus and phy
    */
   const char *phy_id;
 
   u8 rmii_en;
   u8 version;
   bool no_bd_ram;
   void (*interrupt_enable) (void);
   void (*interrupt_disable) (void);
};
 
enum {
   EMAC_VERSION_1,    /* DM644x */
   EMAC_VERSION_2,    /* DM646x */
};
 
#endif