Merge pull request #3 in PROCESSOR-SDK/ibl from PRSDK-5675 to master
[keystone-rtos/ibl.git] / src / hw / mdio / mdio.c
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 }