sn_proc_fs.c
来自「优龙2410linux2.6.8内核源代码」· C语言 代码 · 共 129 行
C
129 行
/* * This file is subject to the terms and conditions of the GNU General Public * License. See the file "COPYING" in the main directory of this archive * for more details. * * Copyright (C) 2000-2003 Silicon Graphics, Inc. All rights reserved. */#include <linux/config.h>#include <asm/uaccess.h>#ifdef CONFIG_PROC_FS#include <linux/proc_fs.h>#include <asm/sn/sgi.h>#include <asm/sn/sn_sal.h>static int partition_id_read_proc(char *page, char **start, off_t off, int count, int *eof, void *data) { return sprintf(page, "%d\n", sn_local_partid());}static struct proc_dir_entry * sgi_proc_dir;voidregister_sn_partition_id(void) { struct proc_dir_entry *entry; if (!sgi_proc_dir) { sgi_proc_dir = proc_mkdir("sgi_sn", 0); } entry = create_proc_entry("partition_id", 0444, sgi_proc_dir); if (entry) { entry->nlink = 1; entry->data = 0; entry->read_proc = partition_id_read_proc; entry->write_proc = NULL; }}static intsystem_serial_number_read_proc(char *page, char **start, off_t off, int count, int *eof, void *data) { return sprintf(page, "%s\n", sn_system_serial_number());}static intlicenseID_read_proc(char *page, char **start, off_t off, int count, int *eof, void *data) { return sprintf(page, "0x%lx\n",sn_partition_serial_number_val());}voidregister_sn_serial_numbers(void) { struct proc_dir_entry *entry; if (!sgi_proc_dir) { sgi_proc_dir = proc_mkdir("sgi_sn", 0); } entry = create_proc_entry("system_serial_number", 0444, sgi_proc_dir); if (entry) { entry->nlink = 1; entry->data = 0; entry->read_proc = system_serial_number_read_proc; entry->write_proc = NULL; } entry = create_proc_entry("licenseID", 0444, sgi_proc_dir); if (entry) { entry->nlink = 1; entry->data = 0; entry->read_proc = licenseID_read_proc; entry->write_proc = NULL; }}/* * Enable forced interrupt by default. * When set, the sn interrupt handler writes the force interrupt register on * the bridge chip. The hardware will then send an interrupt message if the * interrupt line is active. This mimics a level sensitive interrupt. */int sn_force_interrupt_flag = 1;static intsn_force_interrupt_read_proc(char *page, char **start, off_t off, int count, int *eof, void *data) { if (sn_force_interrupt_flag) { return sprintf(page, "Force interrupt is enabled\n"); } return sprintf(page, "Force interrupt is disabled\n");}static int sn_force_interrupt_write_proc(struct file *file, const char *buffer, unsigned long count, void *data){ if (*buffer == '0') { sn_force_interrupt_flag = 0; } else { sn_force_interrupt_flag = 1; } return 1;}voidregister_sn_force_interrupt(void) { struct proc_dir_entry *entry; if (!sgi_proc_dir) { sgi_proc_dir = proc_mkdir("sgi_sn", 0); } entry = create_proc_entry("sn_force_interrupt",0444, sgi_proc_dir); if (entry) { entry->nlink = 1; entry->data = 0; entry->read_proc = sn_force_interrupt_read_proc; entry->write_proc = sn_force_interrupt_write_proc; }}voidregister_sn_procfs(void) { register_sn_partition_id(); register_sn_serial_numbers(); register_sn_force_interrupt();}#endif /* CONFIG_PROC_FS */
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?