Quellcodebibliothek Statistik Leitseite products/sources/formale Sprachen/C/Linux/drivers/hwtracing/coresight/   (Open Source Betriebssystem Version 6.17.9©)  Datei vom 24.10.2025 mit Größe 3 kB image not shown  

Quelle  coresight-catu.h   Sprache: C

 
/* SPDX-License-Identifier: GPL-2.0 */
/*
 * Copyright (C) 2018 Arm Limited. All rights reserved.
 *
 * Author: Suzuki K Poulose <suzuki.poulose@arm.com>
 */


#ifndef _CORESIGHT_CATU_H
#define _CORESIGHT_CATU_H

#include "coresight-priv.h"

/* Register offset from base */
#define CATU_CONTROL  0x000
#define CATU_MODE  0x004
#define CATU_AXICTRL  0x008
#define CATU_IRQEN  0x00c
#define CATU_SLADDRLO  0x020
#define CATU_SLADDRHI  0x024
#define CATU_INADDRLO  0x028
#define CATU_INADDRHI  0x02c
#define CATU_STATUS  0x100
#define CATU_DEVARCH  0xfbc

#define CATU_CONTROL_ENABLE 0

#define CATU_MODE_PASS_THROUGH 0U
#define CATU_MODE_TRANSLATE 1U

#define CATU_AXICTRL_ARCACHE_SHIFT 4
#define CATU_AXICTRL_ARCACHE_MASK 0xf
#define CATU_AXICTRL_ARPROT_MASK 0x3
#define CATU_AXICTRL_ARCACHE(arcache)  \
 (((arcache) & CATU_AXICTRL_ARCACHE_MASK) << CATU_AXICTRL_ARCACHE_SHIFT)

#define CATU_AXICTRL_VAL(arcache, arprot) \
 (CATU_AXICTRL_ARCACHE(arcache) | ((arprot) & CATU_AXICTRL_ARPROT_MASK))

#define AXI3_AxCACHE_WB_READ_ALLOC 0x7
/*
 * AXI - ARPROT bits:
 * See AMBA AXI & ACE Protocol specification (ARM IHI 0022E)
 * sectionA4.7 Access Permissions.
 *
 * Bit 0: 0 - Unprivileged access, 1 - Privileged access
 * Bit 1: 0 - Secure access, 1 - Non-secure access.
 * Bit 2: 0 - Data access, 1 - instruction access.
 *
 * CATU AXICTRL:ARPROT[2] is res0 as we always access data.
 */

#define CATU_OS_ARPROT   0x2

#define CATU_OS_AXICTRL  \
 CATU_AXICTRL_VAL(AXI3_AxCACHE_WB_READ_ALLOC, CATU_OS_ARPROT)

#define CATU_STATUS_READY 8
#define CATU_STATUS_ADRERR 0
#define CATU_STATUS_AXIERR 4

#define CATU_IRQEN_ON  0x1
#define CATU_IRQEN_OFF  0x0

struct catu_drvdata {
 struct clk *pclk;
 struct clk *atclk;
 void __iomem *base;
 struct coresight_device *csdev;
 int irq;
 raw_spinlock_t spinlock;
};

#define CATU_REG32(name, offset)     \
static inline u32       \
catu_read_##name(struct catu_drvdata *drvdata)    \
{         \
 return csdev_access_relaxed_read32(&drvdata->csdev->access, offset); \
}         \
static inline void       \
catu_write_##name(struct catu_drvdata *drvdata, u32 val)  \
{         \
 csdev_access_relaxed_write32(&drvdata->csdev->access, val, offset); \
}

#define CATU_REG_PAIR(name, lo_off, hi_off)    \
static inline u64       \
catu_read_##name(struct catu_drvdata *drvdata)    \
{         \
 return csdev_access_relaxed_read_pair(&drvdata->csdev->access, lo_off, hi_off); \
}         \
static inline void       \
catu_write_##name(struct catu_drvdata *drvdata, u64 val)  \
{         \
 csdev_access_relaxed_write_pair(&drvdata->csdev->access, val, lo_off, hi_off); \
}

CATU_REG32(control, CATU_CONTROL);
CATU_REG32(mode, CATU_MODE);
CATU_REG32(irqen, CATU_IRQEN);
CATU_REG32(axictrl, CATU_AXICTRL);
CATU_REG_PAIR(sladdr, CATU_SLADDRLO, CATU_SLADDRHI)
CATU_REG_PAIR(inaddr, CATU_INADDRLO, CATU_INADDRHI)

static inline bool coresight_is_catu_device(struct coresight_device *csdev)
{
 if (!IS_ENABLED(CONFIG_CORESIGHT_CATU))
  return false;
 if (csdev->type != CORESIGHT_DEV_TYPE_HELPER)
  return false;
 if (csdev->subtype.helper_subtype != CORESIGHT_DEV_SUBTYPE_HELPER_CATU)
  return false;
 return true;
}

#endif

Messung V0.5
C=93 H=95 G=93

¤ Dauer der Verarbeitung: 0.3 Sekunden  ¤

*© Formatika GbR, Deutschland






Wurzel

Suchen

Beweissystem der NASA

Beweissystem Isabelle

NIST Cobol Testsuite

Cephes Mathematical Library

Wiener Entwicklungsmethode

Haftungshinweis

Die Informationen auf dieser Webseite wurden nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit, noch Qualität der bereit gestellten Informationen zugesichert.

Bemerkung:

Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.