Nut/OS  4.10.3
API Reference
cy2239x.h
Go to the documentation of this file.
00001 #ifndef _DEV_CY2239X_H_
00002 #define _DEV_CY2239X_H_
00003 
00004 /*
00005  * Copyright (C) 2005 by egnite Software GmbH. All rights reserved.
00006  *
00007  * Redistribution and use in source and binary forms, with or without
00008  * modification, are permitted provided that the following conditions
00009  * are met:
00010  *
00011  * 1. Redistributions of source code must retain the above copyright
00012  *    notice, this list of conditions and the following disclaimer.
00013  * 2. Redistributions in binary form must reproduce the above copyright
00014  *    notice, this list of conditions and the following disclaimer in the
00015  *    documentation and/or other materials provided with the distribution.
00016  * 3. Neither the name of the copyright holders nor the names of
00017  *    contributors may be used to endorse or promote products derived
00018  *    from this software without specific prior written permission.
00019  *
00020  * THIS SOFTWARE IS PROVIDED BY EGNITE SOFTWARE GMBH AND CONTRIBUTORS
00021  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00022  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00023  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL EGNITE
00024  * SOFTWARE GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00025  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00026  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
00027  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
00028  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
00029  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
00030  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00031  * SUCH DAMAGE.
00032  *
00033  * For additional information see http://www.ethernut.de/
00034  */
00035 
00036 /*
00037  * $Log$
00038  * Revision 1.4  2009/01/17 11:26:47  haraldkipp
00039  * Getting rid of two remaining BSD types in favor of stdint.
00040  * Replaced 'u_int' by 'unsinged int' and 'uptr_t' by 'uintptr_t'.
00041  *
00042  * Revision 1.3  2008/08/11 06:59:59  haraldkipp
00043  * BSD types replaced by stdint types (feature request #1282721).
00044  *
00045  * Revision 1.2  2006/01/05 16:53:26  haraldkipp
00046  * Several new functions added to query and modify the clock settings.
00047  *
00048  * Revision 1.1  2005/10/24 11:41:39  haraldkipp
00049  * Initial check-in.
00050  *
00051  */
00052 
00057 
00058 #include <sys/types.h>
00059 
00065 #define CY2239X_CLKA    0
00066 
00072 #define CY2239X_CLKB    1
00073 
00079 #define CY2239X_CLKC    2
00080 
00086 #define CY2239X_CLKD    3
00087 
00094 #define CY2239X_CLKE    4
00095 
00096 
00098 #define CY2239X_REF     0
00099 
00105 #define CY2239X_PLL1    1
00106 
00112 #define CY2239X_PLL2    2
00113 
00119 #define CY2239X_PLL3    3
00120 
00123 __BEGIN_DECLS
00124 /* Prototypes */
00125 
00126 extern uint32_t Cy2239xGetFreq(int clk, int fctrl);
00127 
00128 extern int Cy2239xGetPll(int clk);
00129 extern int Cy2239xSetPll(int clk, int pll);
00130 
00131 extern int Cy2239xGetDivider(int clk, int fctrl);
00132 extern int Cy2239xSetDivider(int clk, int sel, int val);
00133 
00134 extern int Cy2239xPllEnable(int pll, int fctrl, int ena);
00135 
00136 extern uint32_t Cy2239xPllGetFreq(int pll, int fctrl);
00137 extern int Cy2239xPllSetFreq(int pll, int fctrl, unsigned int pval, unsigned int poff, unsigned int qval, unsigned int fval);
00138 
00139 __END_DECLS
00140 /* End of prototypes */
00141 #endif