Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/C/Linux/tools/testing/selftests/vDSO/   (Open Source Betriebssystem Version 6.17.9©)  Datei vom 24.10.2025 mit Größe 1 kB image not shown  

Quelle  vdso_test_getcpu.c   Sprache: C

 
// SPDX-License-Identifier: GPL-2.0-only
/*
 * vdso_test_getcpu.c: Sample code to test parse_vdso.c and vDSO getcpu()
 *
 * Copyright (c) 2020 Arm Ltd
 */


#include <stdint.h>
#include <elf.h>
#include <stdio.h>
#include <sys/auxv.h>
#include <sys/time.h>

#include "../kselftest.h"
#include "parse_vdso.h"
#include "vdso_config.h"
#include "vdso_call.h"

struct getcpu_cache;
typedef long (*getcpu_t)(unsigned int *, unsigned int *,
    struct getcpu_cache *);

int main(int argc, char **argv)
{
 const char *version = versions[VDSO_VERSION];
 const char **name = (const char **)&names[VDSO_NAMES];
 unsigned long sysinfo_ehdr;
 unsigned int cpu, node;
 getcpu_t get_cpu;
 long ret;

 sysinfo_ehdr = getauxval(AT_SYSINFO_EHDR);
 if (!sysinfo_ehdr) {
  printf("AT_SYSINFO_EHDR is not present!\n");
  return KSFT_SKIP;
 }

 vdso_init_from_sysinfo_ehdr(getauxval(AT_SYSINFO_EHDR));

 get_cpu = (getcpu_t)vdso_sym(version, name[4]);
 if (!get_cpu) {
  printf("Could not find %s\n", name[4]);
  return KSFT_SKIP;
 }

 ret = VDSO_CALL(get_cpu, 3, &cpu, &node, 0);
 if (ret == 0) {
  printf("Running on CPU %u node %u\n", cpu, node);
 } else {
  printf("%s failed\n", name[4]);
  return KSFT_FAIL;
 }

 return 0;
}

Messung V0.5
C=99 H=96 G=97

¤ Dauer der Verarbeitung: 0.12 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.