mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-22 20:43:56 +08:00
a320471147
Minor whitespace cleanups to make checkpatch happy. Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
135 lines
4.0 KiB
C
135 lines
4.0 KiB
C
/************************************************************************
|
|
*
|
|
* io_edgeport.h Edgeport Linux Interface definitions
|
|
*
|
|
* Copyright (C) 2000 Inside Out Networks, Inc.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
*
|
|
************************************************************************/
|
|
|
|
#if !defined(_IO_EDGEPORT_H_)
|
|
#define _IO_EDGEPORT_H_
|
|
|
|
|
|
#define MAX_RS232_PORTS 8 /* Max # of RS-232 ports per device */
|
|
|
|
/* typedefs that the insideout headers need */
|
|
#ifndef LOW8
|
|
#define LOW8(a) ((unsigned char)(a & 0xff))
|
|
#endif
|
|
#ifndef HIGH8
|
|
#define HIGH8(a) ((unsigned char)((a & 0xff00) >> 8))
|
|
#endif
|
|
|
|
#ifndef __KERNEL__
|
|
#define __KERNEL__
|
|
#endif
|
|
|
|
#include "io_usbvend.h"
|
|
|
|
|
|
|
|
/* The following table is used to map the USBx port number to
|
|
* the device serial number (or physical USB path), */
|
|
#define MAX_EDGEPORTS 64
|
|
|
|
struct comMapper {
|
|
char SerialNumber[MAX_SERIALNUMBER_LEN+1]; /* Serial number/usb path */
|
|
int numPorts; /* Number of ports */
|
|
int Original[MAX_RS232_PORTS]; /* Port numbers set by IOCTL */
|
|
int Port[MAX_RS232_PORTS]; /* Actual used port numbers */
|
|
};
|
|
|
|
|
|
#define EDGEPORT_CONFIG_DEVICE "/proc/edgeport"
|
|
|
|
/* /proc/edgeport Interface
|
|
* This interface uses read/write/lseek interface to talk to the edgeport driver
|
|
* the following read functions are supported: */
|
|
#define PROC_GET_MAPPING_TO_PATH 1
|
|
#define PROC_GET_COM_ENTRY 2
|
|
#define PROC_GET_EDGE_MANUF_DESCRIPTOR 3
|
|
#define PROC_GET_BOOT_DESCRIPTOR 4
|
|
#define PROC_GET_PRODUCT_INFO 5
|
|
#define PROC_GET_STRINGS 6
|
|
#define PROC_GET_CURRENT_COM_MAPPING 7
|
|
|
|
/* The parameters to the lseek() for the read is: */
|
|
#define PROC_READ_SETUP(Command, Argument) ((Command) + ((Argument)<<8))
|
|
|
|
|
|
/* the following write functions are supported: */
|
|
#define PROC_SET_COM_MAPPING 1
|
|
#define PROC_SET_COM_ENTRY 2
|
|
|
|
|
|
/* The following sturcture is passed to the write */
|
|
struct procWrite {
|
|
int Command;
|
|
union {
|
|
struct comMapper Entry;
|
|
int ComMappingBasedOnUSBPort; /* Boolean value */
|
|
} u;
|
|
};
|
|
|
|
/*
|
|
* Product information read from the Edgeport
|
|
*/
|
|
struct edgeport_product_info {
|
|
__u16 ProductId; /* Product Identifier */
|
|
__u8 NumPorts; /* Number of ports on edgeport */
|
|
__u8 ProdInfoVer; /* What version of structure is this? */
|
|
|
|
__u32 IsServer :1; /* Set if Server */
|
|
__u32 IsRS232 :1; /* Set if RS-232 ports exist */
|
|
__u32 IsRS422 :1; /* Set if RS-422 ports exist */
|
|
__u32 IsRS485 :1; /* Set if RS-485 ports exist */
|
|
__u32 IsReserved :28; /* Reserved for later expansion */
|
|
|
|
__u8 RomSize; /* Size of ROM/E2PROM in K */
|
|
__u8 RamSize; /* Size of external RAM in K */
|
|
__u8 CpuRev; /* CPU revision level (chg only if s/w visible) */
|
|
__u8 BoardRev; /* PCB revision level (chg only if s/w visible) */
|
|
|
|
__u8 BootMajorVersion; /* Boot Firmware version: xx. */
|
|
__u8 BootMinorVersion; /* yy. */
|
|
__le16 BootBuildNumber; /* zzzz (LE format) */
|
|
|
|
__u8 FirmwareMajorVersion; /* Operational Firmware version:xx. */
|
|
__u8 FirmwareMinorVersion; /* yy. */
|
|
__le16 FirmwareBuildNumber; /* zzzz (LE format) */
|
|
|
|
__u8 ManufactureDescDate[3]; /* MM/DD/YY when descriptor template was compiled */
|
|
__u8 HardwareType;
|
|
|
|
__u8 iDownloadFile; /* What to download to EPiC device */
|
|
__u8 EpicVer; /* What version of EPiC spec this device supports */
|
|
|
|
struct edge_compatibility_bits Epic;
|
|
};
|
|
|
|
/*
|
|
* Edgeport Stringblock String locations
|
|
*/
|
|
#define EDGESTRING_MANUFNAME 1 /* Manufacture Name */
|
|
#define EDGESTRING_PRODNAME 2 /* Product Name */
|
|
#define EDGESTRING_SERIALNUM 3 /* Serial Number */
|
|
#define EDGESTRING_ASSEMNUM 4 /* Assembly Number */
|
|
#define EDGESTRING_OEMASSEMNUM 5 /* OEM Assembly Number */
|
|
#define EDGESTRING_MANUFDATE 6 /* Manufacture Date */
|
|
#define EDGESTRING_ORIGSERIALNUM 7 /* Serial Number */
|
|
|
|
struct string_block {
|
|
__u16 NumStrings; /* Number of strings in block */
|
|
__u16 Strings[1]; /* Start of string block */
|
|
};
|
|
|
|
|
|
|
|
#endif
|