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

Quelle  decompressor_multi_percpu.c   Sprache: C

 
// SPDX-License-Identifier: GPL-2.0-only
/*
 * Copyright (c) 2013
 * Phillip Lougher <phillip@squashfs.org.uk>
 */


#include <linux/types.h>
#include <linux/slab.h>
#include <linux/percpu.h>
#include <linux/local_lock.h>

#include "squashfs_fs.h"
#include "squashfs_fs_sb.h"
#include "decompressor.h"
#include "squashfs.h"

/*
 * This file implements multi-threaded decompression using percpu
 * variables, one thread per cpu core.
 */


struct squashfs_stream {
 void   *stream;
 local_lock_t lock;
};

static void *squashfs_decompressor_create(struct squashfs_sb_info *msblk,
      void *comp_opts)
{
 struct squashfs_stream *stream;
 struct squashfs_stream __percpu *percpu;
 int err, cpu;

 percpu = alloc_percpu(struct squashfs_stream);
 if (percpu == NULL)
  return ERR_PTR(-ENOMEM);

 for_each_possible_cpu(cpu) {
  stream = per_cpu_ptr(percpu, cpu);
  stream->stream = msblk->decompressor->init(msblk, comp_opts);
  if (IS_ERR(stream->stream)) {
   err = PTR_ERR(stream->stream);
   goto out;
  }
  local_lock_init(&stream->lock);
 }

 kfree(comp_opts);
 return (void *)(__force unsigned long) percpu;

out:
 for_each_possible_cpu(cpu) {
  stream = per_cpu_ptr(percpu, cpu);
  if (!IS_ERR_OR_NULL(stream->stream))
   msblk->decompressor->free(stream->stream);
 }
 free_percpu(percpu);
 return ERR_PTR(err);
}

static void squashfs_decompressor_destroy(struct squashfs_sb_info *msblk)
{
 struct squashfs_stream __percpu *percpu =
   (void __percpu *)(unsigned long) msblk->stream;
 struct squashfs_stream *stream;
 int cpu;

 if (msblk->stream) {
  for_each_possible_cpu(cpu) {
   stream = per_cpu_ptr(percpu, cpu);
   msblk->decompressor->free(stream->stream);
  }
  free_percpu(percpu);
 }
}

static int squashfs_decompress(struct squashfs_sb_info *msblk, struct bio *bio,
 int offset, int length, struct squashfs_page_actor *output)
{
 struct squashfs_stream *stream;
 struct squashfs_stream __percpu *percpu =
   (void __percpu *)(unsigned long) msblk->stream;
 int res;

 local_lock(&percpu->lock);
 stream = this_cpu_ptr(percpu);

 res = msblk->decompressor->decompress(msblk, stream->stream, bio,
           offset, length, output);

 local_unlock(&percpu->lock);

 if (res < 0)
  ERROR("%s decompression failed, data probably corrupt\n",
   msblk->decompressor->name);

 return res;
}

static int squashfs_max_decompressors(void)
{
 return num_possible_cpus();
}

const struct squashfs_decompressor_thread_ops squashfs_decompressor_percpu = {
 .create = squashfs_decompressor_create,
 .destroy = squashfs_decompressor_destroy,
 .decompress = squashfs_decompress,
 .max_decompressors = squashfs_max_decompressors,
};

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

¤ 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.