forked from Imagelibrary/rtems
This patch changes the license to BSD-2 for all source files where the copyright is held by Aeroflex Gaisler, Cobham Gaisler, or Gaisler Research. Some files also includes copyright right statements from OAR and/or embedded Brains in addition to Gaisler. Updates #3053.
111 lines
3.7 KiB
C
111 lines
3.7 KiB
C
/* SPDX-License-Identifier: BSD-2-Clause */
|
|
|
|
/*
|
|
* L4STAT APB-Register Driver.
|
|
*
|
|
* COPYRIGHT (c) 2017.
|
|
* Cobham Gaisler AB.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. 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.
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
#ifndef __L4STAT_H__
|
|
#define __L4STAT_H__
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#define L4STAT_ERR_OK 0
|
|
#define L4STAT_ERR_EINVAL -1
|
|
#define L4STAT_ERR_ERROR -2
|
|
#define L4STAT_ERR_TOOMANY -3
|
|
#define L4STAT_ERR_IMPLEMENTED -4
|
|
|
|
/* Register L4STAT driver to Driver Manager */
|
|
void l4stat_register_drv (void);
|
|
|
|
extern int l4stat_counter_print(unsigned int counter);
|
|
|
|
/*
|
|
* L4STAT CCTRL register fields
|
|
*/
|
|
#define CCTRL_NCPU (0xf << CCTRL_NCPU_BIT)
|
|
#define CCTRL_NCNT_L3STAT (0x1ff << CCTRL_NCNT_BIT)
|
|
#define CCTRL_NCNT (0x1f << CCTRL_NCNT_BIT)
|
|
#define CCTRL_MC (0x1 << CCTRL_MC_BIT)
|
|
#define CCTRL_IA (0x1 << CCTRL_IA_BIT)
|
|
#define CCTRL_DS (0x1 << CCTRL_DS_BIT)
|
|
#define CCTRL_EE (0x1 << CCTRL_EE_BIT)
|
|
#define CCTRL_AE (0x1 << CCTRL_AE_BIT)
|
|
#define CCTRL_EL (0x1 << CCTRL_EL_BIT)
|
|
#define CCTRL_CD (0x1 << CCTRL_CD_BIT)
|
|
#define CCTRL_SU (0x3 << CCTRL_SU_BIT)
|
|
#define CCTRL_CL (0x1 << CCTRL_CL_BIT)
|
|
#define CCTRL_EN (0x1 << CCTRL_EN_BIT)
|
|
#define CCTRL_EVENTID (0xff << CCTRL_EVENTID_BIT)
|
|
#define CCTRL_CPUAHBM (0xf << CCTRL_CPUAHBM_BIT)
|
|
|
|
#define CCTRL_NCPU_BIT 28
|
|
#define CCTRL_NCNT_BIT 23
|
|
#define CCTRL_MC_BIT 22
|
|
#define CCTRL_IA_BIT 21
|
|
#define CCTRL_DS_BIT 20
|
|
#define CCTRL_EE_BIT 19
|
|
#define CCTRL_AE_BIT 18
|
|
#define CCTRL_EL_BIT 17
|
|
#define CCTRL_CD_BIT 16
|
|
#define CCTRL_SU_BIT 14
|
|
#define CCTRL_CL_BIT 13
|
|
#define CCTRL_EN_BIT 12
|
|
#define CCTRL_EVENTID_BIT 4
|
|
#define CCTRL_CPUAHBM_BIT 0
|
|
|
|
#define L4STAT_OPTIONS_EVENT_LEVEL_ENABLE CCTRL_EL
|
|
#define L4STAT_OPTIONS_EVENT_LEVEL_DISABLE 0
|
|
#define L4STAT_OPTIONS_MAXIMUM_DURATION CCTRL_CD
|
|
#define L4STAT_OPTIONS_SUPERVISOR_MODE_FILTER (0x1 << CCTRL_SU_BIT)
|
|
#define L4STAT_OPTIONS_USER_MODE_FILTER (0x2 << CCTRL_SU_BIT)
|
|
#define L4STAT_OPTIONS_NO_FILTER 0
|
|
#define L4STAT_OPTIONS_CLEAR_ON_READ CCTRL_CL
|
|
|
|
extern int l4stat_counter_enable(unsigned int counter, int event, int cpu, int options);
|
|
extern int l4stat_counter_disable(unsigned int counter);
|
|
extern int l4stat_counter_set(unsigned int counter, uint32_t val);
|
|
extern int l4stat_counter_get(unsigned int counter, uint32_t *val);
|
|
|
|
static inline int l4stat_counter_clear(unsigned int counter)
|
|
{
|
|
return l4stat_counter_set(counter, 0);
|
|
}
|
|
|
|
extern int l4stat_counter_max_set(unsigned int counter, uint32_t val);
|
|
extern int l4stat_counter_max_get(unsigned int counter, uint32_t *val);
|
|
extern int l4stat_tstamp_set(uint32_t val);
|
|
extern int l4stat_tstamp_get(uint32_t *val);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif
|