drivers/gpib/include/gpib_cmd.h
Source file repositories/reference/linux-study-clean/drivers/gpib/include/gpib_cmd.h
File Facts
- System
- Linux kernel
- Corpus path
drivers/gpib/include/gpib_cmd.h- Extension
.h- Size
- 2383 bytes
- Lines
- 113
- Domain
- Driver Families
- Bucket
- drivers/gpib
- Inferred role
- Driver Families: implementation source
- Status
- source implementation candidate
Why This File Exists
Repeatable hardware-adapter layer. Deep compatibility for every driver is out of scope; this atlas records patterns, probe lifecycles, bus glue, IRQ/DMA usage, and links back to core abstractions.
- Repeatable hardware-adapter layer. Deep compatibility for every driver is out of scope; this atlas records patterns, probe lifecycles, bus glue, IRQ/DMA usage, and links back to core abstractions.
Dependency Surface
linux/types.h
Detected Declarations
enum cmd_bytefunction gpib_address_restrictfunction MLAfunction MTAfunction MSAfunction gpib_address_equalfunction is_PPEfunction is_PPDfunction in_addressed_command_groupfunction in_universal_command_groupfunction in_listen_address_groupfunction in_talk_address_groupfunction in_primary_command_group
Annotated Snippet
#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;
}
Annotation
- Immediate include surface: `linux/types.h`.
- Detected declarations: `enum cmd_byte`, `function gpib_address_restrict`, `function MLA`, `function MTA`, `function MSA`, `function gpib_address_equal`, `function is_PPE`, `function is_PPD`, `function in_addressed_command_group`, `function in_universal_command_group`.
- Atlas domain: Driver Families / drivers/gpib.
- Implementation status: source implementation candidate.
Implementation Notes
- This generated page is the file-by-file coverage layer; curated subsystem chapters should link here when they synthesize a multi-file control flow.
- Core OS pages should be promoted from atlas-only to deep-reviewed when they explain data structures, invariants, locking, lifecycle, and C implementation snippets.
- Driver-family pages are intentionally pattern-oriented unless they are part of the selected PCIe/NVMe representative device path.