cregit-Linux how code gets into the kernel

Release 4.11 drivers/mtd/devices/mtdram.c

/*
 * mtdram - a test mtd device
 * Author: Alexander Larsson <alex@cendio.se>
 *
 * Copyright (c) 1999 Alexander Larsson <alex@cendio.se>
 * Copyright (c) 2005 Joern Engel <joern@wh.fh-wedel.de>
 *
 * This code is GPL
 *
 */

#include <linux/module.h>
#include <linux/slab.h>
#include <linux/ioport.h>
#include <linux/vmalloc.h>
#include <linux/init.h>
#include <linux/mtd/mtd.h>
#include <linux/mtd/mtdram.h>


static unsigned long total_size = CONFIG_MTDRAM_TOTAL_SIZE;

static unsigned long erase_size = CONFIG_MTDRAM_ERASE_SIZE;

static unsigned long writebuf_size = 64;

#define MTDRAM_TOTAL_SIZE (total_size * 1024)

#define MTDRAM_ERASE_SIZE (erase_size * 1024)

#ifdef MODULE
module_param(total_size, ulong, 0);
MODULE_PARM_DESC(total_size, "Total device size in KiB");
module_param(erase_size, ulong, 0);
MODULE_PARM_DESC(erase_size, "Device erase block size in KiB");
module_param(writebuf_size, ulong, 0);
MODULE_PARM_DESC(writebuf_size, "Device write buf size in Bytes (Default: 64)");
#endif

// We could store these in the mtd structure, but we only support 1 device..

static struct mtd_info *mtd_info;


static int check_offs_len(struct mtd_info *mtd, loff_t ofs, uint64_t len) { int ret = 0; /* Start address must align on block boundary */ if (mtd_mod_by_eb(ofs, mtd)) { pr_debug("%s: unaligned address\n", __func__); ret = -EINVAL; } /* Length must align on block boundary */ if (mtd_mod_by_eb(len, mtd)) { pr_debug("%s: length not block aligned\n", __func__); ret = -EINVAL; } return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Dongsheng Yang73100.00%1100.00%
Total73100.00%1100.00%


static int ram_erase(struct mtd_info *mtd, struct erase_info *instr) { if (check_offs_len(mtd, instr->addr, instr->len)) return -EINVAL; memset((char *)mtd->priv + instr->addr, 0xff, instr->len); instr->state = MTD_ERASE_DONE; mtd_erase_callback(instr); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Linus Torvalds (pre-git)4868.57%133.33%
Dongsheng Yang1927.14%133.33%
David Woodhouse34.29%133.33%
Total70100.00%3100.00%


static int ram_point(struct mtd_info *mtd, loff_t from, size_t len, size_t *retlen, void **virt, resource_size_t *phys) { *virt = mtd->priv + from; *retlen = len; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Linus Torvalds (pre-git)4085.11%150.00%
Jared Hulbert714.89%150.00%
Total47100.00%2100.00%


static int ram_unpoint(struct mtd_info *mtd, loff_t from, size_t len) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Linus Torvalds (pre-git)945.00%133.33%
Artem B. Bityutskiy630.00%133.33%
David Woodhouse525.00%133.33%
Total20100.00%3100.00%

/* * Allow NOMMU mmap() to directly map the device (if not NULL) * - return the address to which the offset maps * - return -ENOSYS to indicate refusal to do the mapping */
static unsigned long ram_get_unmapped_area(struct mtd_info *mtd, unsigned long len, unsigned long offset, unsigned long flags) { return (unsigned long) mtd->priv + offset; }

Contributors

PersonTokensPropCommitsCommitProp
David Howells35100.00%1100.00%
Total35100.00%1100.00%


static int ram_read(struct mtd_info *mtd, loff_t from, size_t len, size_t *retlen, u_char *buf) { memcpy(buf, mtd->priv + from, len); *retlen = len; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Linus Torvalds (pre-git)46100.00%1100.00%
Total46100.00%1100.00%


static int ram_write(struct mtd_info *mtd, loff_t to, size_t len, size_t *retlen, const u_char *buf) { memcpy((char *)mtd->priv + to, buf, len); *retlen = len; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Linus Torvalds (pre-git)51100.00%1100.00%
Total51100.00%1100.00%


static void __exit cleanup_mtdram(void) { if (mtd_info) { mtd_device_unregister(mtd_info); vfree(mtd_info->priv); kfree(mtd_info); } }

Contributors

PersonTokensPropCommitsCommitProp
Linus Torvalds (pre-git)2887.50%133.33%
Linus Torvalds39.38%133.33%
Jamie Iles13.12%133.33%
Total32100.00%3100.00%


int mtdram_init_device(struct mtd_info *mtd, void *mapped_address, unsigned long size, const char *name) { memset(mtd, 0, sizeof(*mtd)); /* Setup the MTD structure */ mtd->name = name; mtd->type = MTD_RAM; mtd->flags = MTD_CAP_RAM; mtd->size = size; mtd->writesize = 1; mtd->writebufsize = writebuf_size; mtd->erasesize = MTDRAM_ERASE_SIZE; mtd->priv = mapped_address; mtd->owner = THIS_MODULE; mtd->_erase = ram_erase; mtd->_point = ram_point; mtd->_unpoint = ram_unpoint; mtd->_get_unmapped_area = ram_get_unmapped_area; mtd->_read = ram_read; mtd->_write = ram_write; if (mtd_device_register(mtd, NULL, 0)) return -EIO; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
David Woodhouse7853.79%218.18%
Linus Torvalds (pre-git)3725.52%19.09%
Artem B. Bityutskiy1711.72%327.27%
Jamie Iles53.45%19.09%
David Howells53.45%19.09%
Linus Torvalds10.69%19.09%
Brian Norris10.69%19.09%
Alexander Stein10.69%19.09%
Total145100.00%11100.00%


static int __init init_mtdram(void) { void *addr; int err; if (!total_size) return -EINVAL; /* Allocate some memory */ mtd_info = kmalloc(sizeof(struct mtd_info), GFP_KERNEL); if (!mtd_info) return -ENOMEM; addr = vmalloc(MTDRAM_TOTAL_SIZE); if (!addr) { kfree(mtd_info); mtd_info = NULL; return -ENOMEM; } err = mtdram_init_device(mtd_info, addr, MTDRAM_TOTAL_SIZE, "mtdram test device"); if (err) { vfree(addr); kfree(mtd_info); mtd_info = NULL; return err; } memset(mtd_info->priv, 0xff, MTDRAM_TOTAL_SIZE); return err; }

Contributors

PersonTokensPropCommitsCommitProp
David Woodhouse8971.20%240.00%
Linus Torvalds (pre-git)3024.00%120.00%
Linus Torvalds43.20%120.00%
Jörn Engel21.60%120.00%
Total125100.00%5100.00%

module_init(init_mtdram); module_exit(cleanup_mtdram); MODULE_LICENSE("GPL"); MODULE_AUTHOR("Alexander Larsson <alexl@redhat.com>"); MODULE_DESCRIPTION("Simulated MTD driver for testing");

Overall Contributors

PersonTokensPropCommitsCommitProp
Linus Torvalds (pre-git)31740.59%14.55%
David Woodhouse19524.97%418.18%
Dongsheng Yang9211.78%14.55%
Linus Torvalds506.40%313.64%
David Howells415.25%14.55%
Alexander Stein243.07%14.55%
Artem B. Bityutskiy232.94%418.18%
Jörn Engel131.66%14.55%
Andrew Morton81.02%14.55%
Jared Hulbert70.90%14.55%
Jamie Iles60.77%14.55%
Adrian Bunk40.51%29.09%
Brian Norris10.13%14.55%
Total781100.00%22100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.