/***********************license start*************** * Copyright (c) 2003-2008 Cavium Networks (support@cavium.com). All rights * reserved. * * * 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 Cavium Networks nor the names of * its contributors may be used to endorse or promote products * derived from this software without specific prior written * permission. * * TO THE MAXIMUM EXTENT PERMITTED BY LAW, THE SOFTWARE IS PROVIDED "AS IS" * AND WITH ALL FAULTS AND CAVIUM NETWORKS MAKES NO PROMISES, REPRESENTATIONS * OR WARRANTIES, EITHER EXPRESS, IMPLIED, STATUTORY, OR OTHERWISE, WITH * RESPECT TO THE SOFTWARE, INCLUDING ITS CONDITION, ITS CONFORMITY TO ANY * REPRESENTATION OR DESCRIPTION, OR THE EXISTENCE OF ANY LATENT OR PATENT * DEFECTS, AND CAVIUM SPECIFICALLY DISCLAIMS ALL IMPLIED (IF ANY) WARRANTIES * OF TITLE, MERCHANTABILITY, NONINFRINGEMENT, FITNESS FOR A PARTICULAR * PURPOSE, LACK OF VIRUSES, ACCURACY OR COMPLETENESS, QUIET ENJOYMENT, QUIET * POSSESSION OR CORRESPONDENCE TO DESCRIPTION. THE ENTIRE RISK ARISING OUT * OF USE OR PERFORMANCE OF THE SOFTWARE LIES WITH YOU. * * * For any questions regarding licensing please contact marketing@caviumnetworks.com * ***********************license end**************************************/ /** * @file * * This module provides system/board information obtained by the bootloader. * *
$Revision: 41586 $
* */ #ifndef __CVMX_SYSINFO_H__ #define __CVMX_SYSINFO_H__ #include "cvmx-app-init.h" #ifdef __cplusplus extern "C" { #endif #define OCTEON_SERIAL_LEN 20 /** * Structure describing application specific information. * __cvmx_app_init() populates this from the cvmx boot descriptor. * This structure is private to simple executive applications, so * no versioning is required. * * This structure must be provided with some fields set in order to use * simple executive functions in other applications (Linux kernel, u-boot, etc.) * The cvmx_sysinfo_minimal_initialize() function is provided to set the required values * in these cases. * * */ typedef struct { /* System wide variables */ uint64_t system_dram_size; /**< installed DRAM in system, in bytes */ void *phy_mem_desc_ptr; /**< ptr to memory descriptor block */ /* Application image specific variables */ uint64_t stack_top; /**< stack top address (virtual) */ uint64_t heap_base; /**< heap base address (virtual) */ uint32_t stack_size; /**< stack size in bytes */ uint32_t heap_size; /**< heap size in bytes */ uint32_t core_mask; /**< coremask defining cores running application */ uint32_t init_core; /**< Deprecated, use cvmx_coremask_first_core() to select init core */ uint64_t exception_base_addr; /**< exception base address, as set by bootloader */ uint32_t cpu_clock_hz; /**< cpu clock speed in hz */ uint32_t dram_data_rate_hz; /**< dram data rate in hz (data rate = 2 * clock rate */ uint16_t board_type; uint8_t board_rev_major; uint8_t board_rev_minor; uint8_t mac_addr_base[6]; uint8_t mac_addr_count; char board_serial_number[OCTEON_SERIAL_LEN]; /* Several boards support compact flash on the Octeon boot bus. The CF ** memory spaces may be mapped to different addresses on different boards. ** These values will be 0 if CF is not present. ** Note that these addresses are physical addresses, and it is up to the application ** to use the proper addressing mode (XKPHYS, KSEG0, etc.)*/ uint64_t compact_flash_common_base_addr; uint64_t compact_flash_attribute_base_addr; /* Base address of the LED display (as on EBT3000 board) ** This will be 0 if LED display not present. ** Note that this address is a physical address, and it is up to the application ** to use the proper addressing mode (XKPHYS, KSEG0, etc.)*/ uint64_t led_display_base_addr; uint32_t dfa_ref_clock_hz; /**< DFA reference clock in hz (if applicable)*/ uint32_t bootloader_config_flags; /**< configuration flags from bootloader */ uint8_t console_uart_num; /** < Uart number used for console */ } cvmx_sysinfo_t; /** * This function returns the system/board information as obtained * by the bootloader. * * * @return Pointer to the boot information structure * */ extern cvmx_sysinfo_t * cvmx_sysinfo_get(void); /** * This function is used in non-simple executive environments (such as Linux kernel, u-boot, etc.) * to configure the minimal fields that are required to use * simple executive files directly. * * Locking (if required) must be handled outside of this * function * * @param phy_mem_desc_ptr * Pointer to global physical memory descriptor (bootmem descriptor) * @param board_type Octeon board type enumeration * * @param board_rev_major * Board major revision * @param board_rev_minor * Board minor revision * @param cpu_clock_hz * CPU clock freqency in hertz * * @return 0: Failure * 1: success */ extern int cvmx_sysinfo_minimal_initialize(void *phy_mem_desc_ptr, uint16_t board_type, uint8_t board_rev_major, uint8_t board_rev_minor, uint32_t cpu_clock_hz); #ifdef CVMX_BUILD_FOR_LINUX_USER /** * Initialize the sysinfo structure when running on * Octeon under Linux userspace */ extern void cvmx_sysinfo_linux_userspace_initialize(void); #endif #ifdef __cplusplus } #endif #endif /* __CVMX_SYSINFO_H__ */