mirror of
https://github.com/torvalds/linux.git
synced 2025-12-07 20:06:24 +00:00
Move the gpib drivers out of staging and into the "real" part of the kernel. This entails: - Remove the gpib Kconfig menu and Makefile build rule from staging. - Remove gpib/uapi from the header file search path in subdir-ccflags of the gpib Makefile - move the gpib/uapi files to include/uapi/linux - Move the gpib tree out of staging to drivers. - Remove the word "Linux" from the gpib Kconfig file. - Add the gpib Kconfig menu and Makefile build rule to drivers Signed-off-by: Dave Penkler <dpenkler@gmail.com> Link: https://patch.msgid.link/20251117144021.23569-5-dpenkler@gmail.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
113 lines
2.3 KiB
C
113 lines
2.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
#ifndef _GPIB_CMD_H
|
|
#define _GPIB_CMD_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
/* Command byte definitions tests and functions */
|
|
|
|
/* mask of bits that actually matter in a command byte */
|
|
enum {
|
|
gpib_command_mask = 0x7f,
|
|
};
|
|
|
|
/* Possible GPIB command messages */
|
|
|
|
enum cmd_byte {
|
|
GTL = 0x1, /* go to local */
|
|
SDC = 0x4, /* selected device clear */
|
|
PP_CONFIG = 0x5,
|
|
GET = 0x8, /* group execute trigger */
|
|
TCT = 0x9, /* take control */
|
|
LLO = 0x11, /* local lockout */
|
|
DCL = 0x14, /* device clear */
|
|
PPU = 0x15, /* parallel poll unconfigure */
|
|
SPE = 0x18, /* serial poll enable */
|
|
SPD = 0x19, /* serial poll disable */
|
|
CFE = 0x1f, /* configure enable */
|
|
LAD = 0x20, /* value to be 'ored' in to obtain listen address */
|
|
UNL = 0x3F, /* unlisten */
|
|
TAD = 0x40, /* value to be 'ored' in to obtain talk address */
|
|
UNT = 0x5F, /* untalk */
|
|
SAD = 0x60, /* my secondary address (base) */
|
|
PPE = 0x60, /* parallel poll enable (base) */
|
|
PPD = 0x70 /* parallel poll disable */
|
|
};
|
|
|
|
/* confine address to range 0 to 30. */
|
|
static inline unsigned int gpib_address_restrict(u32 addr)
|
|
{
|
|
addr &= 0x1f;
|
|
if (addr == 0x1f)
|
|
addr = 0;
|
|
return addr;
|
|
}
|
|
|
|
static inline u8 MLA(u32 addr)
|
|
{
|
|
return gpib_address_restrict(addr) | LAD;
|
|
}
|
|
|
|
static inline u8 MTA(u32 addr)
|
|
{
|
|
return gpib_address_restrict(addr) | TAD;
|
|
}
|
|
|
|
static inline u8 MSA(u32 addr)
|
|
{
|
|
return (addr & 0x1f) | SAD;
|
|
}
|
|
|
|
static inline s32 gpib_address_equal(u32 pad1, s32 sad1, u32 pad2, s32 sad2)
|
|
{
|
|
if (pad1 == pad2) {
|
|
if (sad1 == sad2)
|
|
return 1;
|
|
if (sad1 < 0 && sad2 < 0)
|
|
return 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
static inline s32 is_PPE(u8 command)
|
|
{
|
|
return (command & 0x70) == 0x60;
|
|
}
|
|
|
|
static inline s32 is_PPD(u8 command)
|
|
{
|
|
return (command & 0x70) == 0x70;
|
|
}
|
|
|
|
static inline s32 in_addressed_command_group(u8 command)
|
|
{
|
|
return (command & 0x70) == 0x0;
|
|
}
|
|
|
|
static inline s32 in_universal_command_group(u8 command)
|
|
{
|
|
return (command & 0x70) == 0x10;
|
|
}
|
|
|
|
static inline s32 in_listen_address_group(u8 command)
|
|
{
|
|
return (command & 0x60) == 0x20;
|
|
}
|
|
|
|
static inline s32 in_talk_address_group(u8 command)
|
|
{
|
|
return (command & 0x60) == 0x40;
|
|
}
|
|
|
|
static inline s32 in_primary_command_group(u8 command)
|
|
{
|
|
return in_addressed_command_group(command) ||
|
|
in_universal_command_group(command) ||
|
|
in_listen_address_group(command) ||
|
|
in_talk_address_group(command);
|
|
}
|
|
|
|
#endif /* _GPIB_CMD_H */
|