1 /*
2 *
3 * Copyright (C) 2010 Texas Instruments Incorporated - http://www.ti.com/
4 *
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 *
13 * Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the
16 * distribution.
17 *
18 * Neither the name of Texas Instruments Incorporated nor the names of
19 * its contributors may be used to endorse or promote products derived
20 * from this software without specific prior written permission.
21 *
22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
25 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
26 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
27 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
28 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
29 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
30 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
31 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
32 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33 *
34 */
38 /**********************************************************************************
39 * FILE PURPOSE: A very simple mdio driver
40 **********************************************************************************
41 * FILE NAME: mdio.c
42 *
43 * DESCRIPTION: Enables mdio and performs blind access
44 *
45 * @file mdio.c
46 *
47 * @brief
48 * Enables mdio and performs blind access
49 *
50 **********************************************************************************/
51 #include "types.h"
52 #include "mdio.h"
53 #include "device.h"
55 /***********************************************************************************
56 * FUNCTION PURPOSE: Provide an approximate delay
57 ***********************************************************************************
58 * DESCRIPTION: A delay in units of CPU cycles is executed
59 ***********************************************************************************/
60 void mdio_delay (uint32 del)
61 {
62 volatile unsigned int i;
64 for (i = 0; i < del/8; i++);
66 }
68 /***********************************************************************************
69 * FUNCTION PURPOSE: Perform blind MDIO access
70 ***********************************************************************************
71 * DESCRIPTION: Pre-configured mdio access is performed.
72 ***********************************************************************************/
73 void hwMdio (int16 nAccess, uint32 *access, uint16 clkdiv, uint32 delayCpuCycles)
74 {
75 int16 i;
77 /* Enable MDIO, set the divider. A divider value of 0 is not allowed */
78 if (clkdiv == 0)
79 clkdiv = 1;
81 MDIOR->CONTROL = (0x40000000 | clkdiv);
84 for (i = 0; i < nAccess; i++) {
86 /* Set the Go bit */
87 MDIOR->USERACCESS0 = (((uint32)1 << 31) | access[i]);
88 while (MDIOR->USERACCESS0 & 0x80000000);
90 mdio_delay (delayCpuCycles);
92 }
94 /* A big delay after the last configure */
95 mdio_delay (1000000);
97 }