1*1da177e4SLinus Torvalds /* 2*1da177e4SLinus Torvalds * File Attributes for Zorro Devices 3*1da177e4SLinus Torvalds * 4*1da177e4SLinus Torvalds * Copyright (C) 2003 Geert Uytterhoeven 5*1da177e4SLinus Torvalds * 6*1da177e4SLinus Torvalds * Loosely based on drivers/pci/pci-sysfs.c 7*1da177e4SLinus Torvalds * 8*1da177e4SLinus Torvalds * This file is subject to the terms and conditions of the GNU General Public 9*1da177e4SLinus Torvalds * License. See the file COPYING in the main directory of this archive 10*1da177e4SLinus Torvalds * for more details. 11*1da177e4SLinus Torvalds */ 12*1da177e4SLinus Torvalds 13*1da177e4SLinus Torvalds 14*1da177e4SLinus Torvalds #include <linux/kernel.h> 15*1da177e4SLinus Torvalds #include <linux/zorro.h> 16*1da177e4SLinus Torvalds #include <linux/stat.h> 17*1da177e4SLinus Torvalds 18*1da177e4SLinus Torvalds #include "zorro.h" 19*1da177e4SLinus Torvalds 20*1da177e4SLinus Torvalds 21*1da177e4SLinus Torvalds /* show configuration fields */ 22*1da177e4SLinus Torvalds #define zorro_config_attr(name, field, format_string) \ 23*1da177e4SLinus Torvalds static ssize_t \ 24*1da177e4SLinus Torvalds show_##name(struct device *dev, char *buf) \ 25*1da177e4SLinus Torvalds { \ 26*1da177e4SLinus Torvalds struct zorro_dev *z; \ 27*1da177e4SLinus Torvalds \ 28*1da177e4SLinus Torvalds z = to_zorro_dev(dev); \ 29*1da177e4SLinus Torvalds return sprintf(buf, format_string, z->field); \ 30*1da177e4SLinus Torvalds } \ 31*1da177e4SLinus Torvalds static DEVICE_ATTR(name, S_IRUGO, show_##name, NULL); 32*1da177e4SLinus Torvalds 33*1da177e4SLinus Torvalds zorro_config_attr(id, id, "0x%08x\n"); 34*1da177e4SLinus Torvalds zorro_config_attr(type, rom.er_Type, "0x%02x\n"); 35*1da177e4SLinus Torvalds zorro_config_attr(serial, rom.er_SerialNumber, "0x%08x\n"); 36*1da177e4SLinus Torvalds zorro_config_attr(slotaddr, slotaddr, "0x%04x\n"); 37*1da177e4SLinus Torvalds zorro_config_attr(slotsize, slotsize, "0x%04x\n"); 38*1da177e4SLinus Torvalds 39*1da177e4SLinus Torvalds static ssize_t zorro_show_resource(struct device *dev, char *buf) 40*1da177e4SLinus Torvalds { 41*1da177e4SLinus Torvalds struct zorro_dev *z = to_zorro_dev(dev); 42*1da177e4SLinus Torvalds 43*1da177e4SLinus Torvalds return sprintf(buf, "0x%08lx 0x%08lx 0x%08lx\n", 44*1da177e4SLinus Torvalds zorro_resource_start(z), zorro_resource_end(z), 45*1da177e4SLinus Torvalds zorro_resource_flags(z)); 46*1da177e4SLinus Torvalds } 47*1da177e4SLinus Torvalds 48*1da177e4SLinus Torvalds static DEVICE_ATTR(resource, S_IRUGO, zorro_show_resource, NULL); 49*1da177e4SLinus Torvalds 50*1da177e4SLinus Torvalds static ssize_t zorro_read_config(struct kobject *kobj, char *buf, loff_t off, 51*1da177e4SLinus Torvalds size_t count) 52*1da177e4SLinus Torvalds { 53*1da177e4SLinus Torvalds struct zorro_dev *z = to_zorro_dev(container_of(kobj, struct device, 54*1da177e4SLinus Torvalds kobj)); 55*1da177e4SLinus Torvalds struct ConfigDev cd; 56*1da177e4SLinus Torvalds unsigned int size = sizeof(cd); 57*1da177e4SLinus Torvalds 58*1da177e4SLinus Torvalds if (off > size) 59*1da177e4SLinus Torvalds return 0; 60*1da177e4SLinus Torvalds if (off+count > size) 61*1da177e4SLinus Torvalds count = size-off; 62*1da177e4SLinus Torvalds 63*1da177e4SLinus Torvalds /* Construct a ConfigDev */ 64*1da177e4SLinus Torvalds memset(&cd, 0, sizeof(cd)); 65*1da177e4SLinus Torvalds cd.cd_Rom = z->rom; 66*1da177e4SLinus Torvalds cd.cd_SlotAddr = z->slotaddr; 67*1da177e4SLinus Torvalds cd.cd_SlotSize = z->slotsize; 68*1da177e4SLinus Torvalds cd.cd_BoardAddr = (void *)zorro_resource_start(z); 69*1da177e4SLinus Torvalds cd.cd_BoardSize = zorro_resource_len(z); 70*1da177e4SLinus Torvalds 71*1da177e4SLinus Torvalds memcpy(buf, (void *)&cd+off, count); 72*1da177e4SLinus Torvalds return count; 73*1da177e4SLinus Torvalds } 74*1da177e4SLinus Torvalds 75*1da177e4SLinus Torvalds static struct bin_attribute zorro_config_attr = { 76*1da177e4SLinus Torvalds .attr = { 77*1da177e4SLinus Torvalds .name = "config", 78*1da177e4SLinus Torvalds .mode = S_IRUGO | S_IWUSR, 79*1da177e4SLinus Torvalds .owner = THIS_MODULE 80*1da177e4SLinus Torvalds }, 81*1da177e4SLinus Torvalds .size = sizeof(struct ConfigDev), 82*1da177e4SLinus Torvalds .read = zorro_read_config, 83*1da177e4SLinus Torvalds }; 84*1da177e4SLinus Torvalds 85*1da177e4SLinus Torvalds void zorro_create_sysfs_dev_files(struct zorro_dev *z) 86*1da177e4SLinus Torvalds { 87*1da177e4SLinus Torvalds struct device *dev = &z->dev; 88*1da177e4SLinus Torvalds 89*1da177e4SLinus Torvalds /* current configuration's attributes */ 90*1da177e4SLinus Torvalds device_create_file(dev, &dev_attr_id); 91*1da177e4SLinus Torvalds device_create_file(dev, &dev_attr_type); 92*1da177e4SLinus Torvalds device_create_file(dev, &dev_attr_serial); 93*1da177e4SLinus Torvalds device_create_file(dev, &dev_attr_slotaddr); 94*1da177e4SLinus Torvalds device_create_file(dev, &dev_attr_slotsize); 95*1da177e4SLinus Torvalds device_create_file(dev, &dev_attr_resource); 96*1da177e4SLinus Torvalds sysfs_create_bin_file(&dev->kobj, &zorro_config_attr); 97*1da177e4SLinus Torvalds } 98*1da177e4SLinus Torvalds 99