Skip to content
This repository
tree: 7138750717
Fetching contributors…

Cannot retrieve contributors at this time

file 117 lines (106 sloc) 3.68 kb
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 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117
/*
*
* @Component OMAPCONF
* @Filename cpuinfo54xx.h
* @Description OMAP5 CPU Info Functions
* @Author Patrick Titiano (p-titiano@ti.com)
* @Date 2011
* @Copyright Texas Instruments Incorporated
*
*
* Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
*
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the
* distribution.
*
* Neither the name of Texas Instruments Incorporated nor the names of
* its contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
*/


#include <cpuinfo54xx.h>
#include <cpuinfo.h>
#include <lib.h>
#include <stdio.h>
#include <stdlib.h>


/* #define CPUID54XX_DEBUG */
#ifdef CPUID54XX_DEBUG
#define dprintf(format, ...) printf(format, ## __VA_ARGS__)
#else
#define dprintf(format, ...)
#endif


/* ------------------------------------------------------------------------*//**
* @FUNCTION cpu54xx_silicon_max_speed_get
* @BRIEF return silicon max speed (depending on cpu type and
* silicon type)
* @RETURNS Silicon max speed (in MHz)
* 0 in case of error
* @DESCRIPTION return silicon max speed (depending on cpu type and
* silicon type)
*//*------------------------------------------------------------------------ */
unsigned int cpu54xx_silicon_max_speed_get(void)
{
unsigned int max_speed;

switch (cpu_get()) {
case OMAP_5430:
case OMAP_5432:
switch (cpu_silicon_type_get()) {
case LOW_PERF_SI:
max_speed = 800;
break;
case STANDARD_PERF_SI:
max_speed = 1000;
break;
case HIGH_PERF_SI:
max_speed = 1200;
break;
default:
max_speed = 0;
break;
}
break;

default:
fprintf(stderr, "%s(): unknown chip!\n", __func__);
max_speed = 0;
}

dprintf("%s(): max speed = %dMHz\n", __func__, max_speed);
return max_speed;
}


/* ------------------------------------------------------------------------*//**
* @FUNCTION cpu54xx_cores_count_get
* @BRIEF return the number of CPU cores available
* @RETURNS >0 number of CPU cores available
* 0 in case of error (unknown architecture)
* @DESCRIPTION return the number of CPU cores available
*//*------------------------------------------------------------------------ */
unsigned int cpu54xx_cores_count_get(void)
{
if (cpu_is_omap54xx()) {
return 2;
} else {
fprintf(stderr, "%s(): unknown architecture!\n", __func__);
return 0;
}
}
Something went wrong with that request. Please try again.