Anforderungen  |   Konzepte  |   Entwurf  |   Entwicklung  |   Qualitätssicherung  |   Lebenszyklus  |   Steuerung
 
 
 
 


Quelle  hypfs_sprp.c   Sprache: C

 
// SPDX-License-Identifier: GPL-2.0
/*
 *    Hypervisor filesystem for Linux on s390.
 *    Set Partition-Resource Parameter interface.
 *
 *    Copyright IBM Corp. 2013
 *    Author(s): Martin Schwidefsky <schwidefsky@de.ibm.com>
 */


#include <linux/compat.h>
#include <linux/errno.h>
#include <linux/gfp.h>
#include <linux/string.h>
#include <linux/types.h>
#include <linux/uaccess.h>
#include <asm/diag.h>
#include <asm/sclp.h>
#include "hypfs.h"

#define DIAG304_SET_WEIGHTS 0
#define DIAG304_QUERY_PRP 1
#define DIAG304_SET_CAPPING 2

#define DIAG304_CMD_MAX  2

static inline unsigned long __hypfs_sprp_diag304(void *data, unsigned long cmd)
{
 union register_pair r1 = { .even = virt_to_phys(data), };

 asm volatile("diag %[r1],%[r3],0x304\n"
       : [r1] "+&d" (r1.pair)
       : [r3] "d" (cmd)
       : "memory");
 return r1.odd;
}

static unsigned long hypfs_sprp_diag304(void *data, unsigned long cmd)
{
 diag_stat_inc(DIAG_STAT_X304);
 return __hypfs_sprp_diag304(data, cmd);
}

static void hypfs_sprp_free(const void *data)
{
 free_page((unsigned long) data);
}

static int hypfs_sprp_create(void **data_ptr, void **free_ptr, size_t *size)
{
 unsigned long rc;
 void *data;

 data = (void *) get_zeroed_page(GFP_KERNEL);
 if (!data)
  return -ENOMEM;
 rc = hypfs_sprp_diag304(data, DIAG304_QUERY_PRP);
 if (rc != 1) {
  *data_ptr = *free_ptr = NULL;
  *size = 0;
  free_page((unsigned long) data);
  return -EIO;
 }
 *data_ptr = *free_ptr = data;
 *size = PAGE_SIZE;
 return 0;
}

static int __hypfs_sprp_ioctl(void __user *user_area)
{
 struct hypfs_diag304 *diag304;
 unsigned long cmd;
 void __user *udata;
 void *data;
 int rc;

 rc = -ENOMEM;
 data = (void *)get_zeroed_page(GFP_KERNEL);
 diag304 = kzalloc(sizeof(*diag304), GFP_KERNEL);
 if (!data || !diag304)
  goto out;

 rc = -EFAULT;
 if (copy_from_user(diag304, user_area, sizeof(*diag304)))
  goto out;
 rc = -EINVAL;
 if ((diag304->args[0] >> 8) != 0 || diag304->args[1] > DIAG304_CMD_MAX)
  goto out;

 rc = -EFAULT;
 udata = (void __user *)(unsigned long) diag304->data;
 if (diag304->args[1] == DIAG304_SET_WEIGHTS ||
     diag304->args[1] == DIAG304_SET_CAPPING)
  if (copy_from_user(data, udata, PAGE_SIZE))
   goto out;

 cmd = *(unsigned long *) &diag304->args[0];
 diag304->rc = hypfs_sprp_diag304(data, cmd);

 if (diag304->args[1] == DIAG304_QUERY_PRP)
  if (copy_to_user(udata, data, PAGE_SIZE)) {
   rc = -EFAULT;
   goto out;
  }

 rc = copy_to_user(user_area, diag304, sizeof(*diag304)) ? -EFAULT : 0;
out:
 kfree(diag304);
 free_page((unsigned long) data);
 return rc;
}

static long hypfs_sprp_ioctl(struct file *file, unsigned int cmd,
          unsigned long arg)
{
 void __user *argp;

 if (!capable(CAP_SYS_ADMIN))
  return -EACCES;
 if (is_compat_task())
  argp = compat_ptr(arg);
 else
  argp = (void __user *) arg;
 switch (cmd) {
 case HYPFS_DIAG304:
  return __hypfs_sprp_ioctl(argp);
 default/* unknown ioctl number */
  return -ENOTTY;
 }
 return 0;
}

static struct hypfs_dbfs_file hypfs_sprp_file = {
 .name  = "diag_304",
 .data_create = hypfs_sprp_create,
 .data_free = hypfs_sprp_free,
 .unlocked_ioctl = hypfs_sprp_ioctl,
};

void hypfs_sprp_init(void)
{
 if (!sclp.has_sprp)
  return;
 hypfs_dbfs_create_file(&hypfs_sprp_file);
}

void hypfs_sprp_exit(void)
{
 if (!sclp.has_sprp)
  return;
 hypfs_dbfs_remove_file(&hypfs_sprp_file);
}

Messung V0.5
C=99 H=85 G=92

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






                                                                                                                                                                                                                                                                                                                                                                                                     


Neuigkeiten

     Aktuelles
     Motto des Tages

Software

     Produkte
     Quellcodebibliothek

Aktivitäten

     Artikel über Sicherheit
     Anleitung zur Aktivierung von SSL

Muße

     Gedichte
     Musik
     Bilder

Jenseits des Üblichen ....

Besucherstatistik

Besucherstatistik

Monitoring

Montastic status badge