18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * HMC Drive DVD Module 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Copyright IBM Corp. 2013 68c2ecf20Sopenharmony_ci * Author(s): Ralf Hoppe (rhoppe@de.ibm.com) 78c2ecf20Sopenharmony_ci */ 88c2ecf20Sopenharmony_ci 98c2ecf20Sopenharmony_ci#define KMSG_COMPONENT "hmcdrv" 108c2ecf20Sopenharmony_ci#define pr_fmt(fmt) KMSG_COMPONENT ": " fmt 118c2ecf20Sopenharmony_ci 128c2ecf20Sopenharmony_ci#include <linux/kernel.h> 138c2ecf20Sopenharmony_ci#include <linux/module.h> 148c2ecf20Sopenharmony_ci#include <linux/moduleparam.h> 158c2ecf20Sopenharmony_ci#include <linux/stat.h> 168c2ecf20Sopenharmony_ci 178c2ecf20Sopenharmony_ci#include "hmcdrv_ftp.h" 188c2ecf20Sopenharmony_ci#include "hmcdrv_dev.h" 198c2ecf20Sopenharmony_ci#include "hmcdrv_cache.h" 208c2ecf20Sopenharmony_ci 218c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL"); 228c2ecf20Sopenharmony_ciMODULE_AUTHOR("Copyright 2013 IBM Corporation"); 238c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("HMC drive DVD access"); 248c2ecf20Sopenharmony_ci 258c2ecf20Sopenharmony_ci/* 268c2ecf20Sopenharmony_ci * module parameter 'cachesize' 278c2ecf20Sopenharmony_ci */ 288c2ecf20Sopenharmony_cistatic size_t hmcdrv_mod_cachesize = HMCDRV_CACHE_SIZE_DFLT; 298c2ecf20Sopenharmony_cimodule_param_named(cachesize, hmcdrv_mod_cachesize, ulong, S_IRUGO); 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_ci/** 328c2ecf20Sopenharmony_ci * hmcdrv_mod_init() - module init function 338c2ecf20Sopenharmony_ci */ 348c2ecf20Sopenharmony_cistatic int __init hmcdrv_mod_init(void) 358c2ecf20Sopenharmony_ci{ 368c2ecf20Sopenharmony_ci int rc = hmcdrv_ftp_probe(); /* perform w/o cache */ 378c2ecf20Sopenharmony_ci 388c2ecf20Sopenharmony_ci if (rc) 398c2ecf20Sopenharmony_ci return rc; 408c2ecf20Sopenharmony_ci 418c2ecf20Sopenharmony_ci rc = hmcdrv_cache_startup(hmcdrv_mod_cachesize); 428c2ecf20Sopenharmony_ci 438c2ecf20Sopenharmony_ci if (rc) 448c2ecf20Sopenharmony_ci return rc; 458c2ecf20Sopenharmony_ci 468c2ecf20Sopenharmony_ci rc = hmcdrv_dev_init(); 478c2ecf20Sopenharmony_ci 488c2ecf20Sopenharmony_ci if (rc) 498c2ecf20Sopenharmony_ci hmcdrv_cache_shutdown(); 508c2ecf20Sopenharmony_ci 518c2ecf20Sopenharmony_ci return rc; 528c2ecf20Sopenharmony_ci} 538c2ecf20Sopenharmony_ci 548c2ecf20Sopenharmony_ci/** 558c2ecf20Sopenharmony_ci * hmcdrv_mod_exit() - module exit function 568c2ecf20Sopenharmony_ci */ 578c2ecf20Sopenharmony_cistatic void __exit hmcdrv_mod_exit(void) 588c2ecf20Sopenharmony_ci{ 598c2ecf20Sopenharmony_ci hmcdrv_dev_exit(); 608c2ecf20Sopenharmony_ci hmcdrv_cache_shutdown(); 618c2ecf20Sopenharmony_ci} 628c2ecf20Sopenharmony_ci 638c2ecf20Sopenharmony_cimodule_init(hmcdrv_mod_init); 648c2ecf20Sopenharmony_cimodule_exit(hmcdrv_mod_exit); 65