Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/C/Linux/arch/mips/include/asm/   (Open Source Betriebssystem Version 6.17.9©)  Datei vom 24.10.2025 mit Größe 2 kB image not shown  

Quelle  ftrace.h   Sprache: C

 
/*
 * This file is subject to the terms and conditions of the GNU General Public
 * License.  See the file "COPYING" in the main directory of this archive for
 * more details.
 *
 * Copyright (C) 2009 DSLab, Lanzhou University, China
 * Author: Wu Zhangjin <wuzhangjin@gmail.com>
 */


#ifndef _ASM_MIPS_FTRACE_H
#define _ASM_MIPS_FTRACE_H

#ifdef CONFIG_FUNCTION_TRACER

#define MCOUNT_ADDR ((unsigned long)(_mcount))
#define MCOUNT_INSN_SIZE 4  /* sizeof mcount call */

#ifndef __ASSEMBLY__
extern void _mcount(void);
#define mcount _mcount

#define safe_load(load, src, dst, error)  \
do {       \
 asm volatile (     \
  "1: " load " %[tmp_dst], 0(%[tmp_src])\n" \
  " li %[tmp_err], 0\n"   \
  "2: .insn\n"    \
       \
  ".section .fixup, \"ax\"\n"  \
  "3: li %[tmp_err], 1\n"   \
  " j 2b\n"    \
  ".previous\n"    \
       \
  ".section\t__ex_table,\"a\"\n\t" \
  STR(PTR_WD) "\t1b, 3b\n\t"  \
  ".previous\n"    \
       \
  : [tmp_dst] "=&r" (dst), [tmp_err] "=r" (error)\
  : [tmp_src] "r" (src)   \
  : "memory"    \
 );      \
while (0)

#define safe_store(store, src, dst, error) \
do {      \
 asm volatile (    \
  "1: " store " %[tmp_src], 0(%[tmp_dst])\n"\
  " li %[tmp_err], 0\n"  \
  "2: .insn\n"   \
      \
  ".section .fixup, \"ax\"\n" \
  "3: li %[tmp_err], 1\n"  \
  " j 2b\n"   \
  ".previous\n"   \
      \
  ".section\t__ex_table,\"a\"\n\t"\
  STR(PTR_WD) "\t1b, 3b\n\t" \
  ".previous\n"   \
      \
  : [tmp_err] "=r" (error) \
  : [tmp_dst] "r" (dst), [tmp_src] "r" (src)\
  : "memory"   \
 );     \
while (0)

#define safe_load_code(dst, src, error) \
 safe_load(STR(lw), src, dst, error)
#define safe_store_code(src, dst, error) \
 safe_store(STR(sw), src, dst, error)

#define safe_load_stack(dst, src, error) \
 safe_load(STR(PTR_L), src, dst, error)

#define safe_store_stack(src, dst, error) \
 safe_store(STR(PTR_S), src, dst, error)


#ifdef CONFIG_DYNAMIC_FTRACE
static inline unsigned long ftrace_call_adjust(unsigned long addr)
{
 return addr;
}

struct dyn_arch_ftrace {
};

#endif /*  CONFIG_DYNAMIC_FTRACE */

void prepare_ftrace_return(unsigned long *parent_ra_addr, unsigned long self_ra,
      unsigned long fp);

#endif /* __ASSEMBLY__ */
#endif /* CONFIG_FUNCTION_TRACER */

#ifdef CONFIG_FTRACE_SYSCALLS
#ifndef __ASSEMBLY__
/*
 * Some syscall entry functions on mips start with "__sys_" (fork and clone,
 * for instance). We should also match the sys_ variant with those.
 */

#define ARCH_HAS_SYSCALL_MATCH_SYM_NAME
static inline bool arch_syscall_match_sym_name(const char *sym,
            const char *name)
{
 return !strcmp(sym, name) ||
  (!strncmp(sym, "__sys_", 6) && !strcmp(sym + 6, name + 4));
}
#endif /* __ASSEMBLY__ */
#endif /* CONFIG_FTRACE_SYSCALLS */
#endif /* _ASM_MIPS_FTRACE_H */

Messung V0.5
C=96 H=84 G=90

¤ Dauer der Verarbeitung: 0.15 Sekunden  (vorverarbeitet)  ¤

*© 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.