rdma

package
v0.6.12 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 31, 2026 License: MIT Imports: 10 Imported by: 0

Documentation

Overview

Package rdma provides Go bindings for the rdma framework.

Code generated from Apple documentation. DO NOT EDIT.

Index

Constants

View Source
const (
	IBV_ACCESS_LOCAL_WRITE  = 1
	IBV_ACCESS_REMOTE_WRITE = 2
	IBV_ACCESS_REMOTE_READ  = 4

	IBV_QPT_UC = 3

	IBV_QPS_INIT = 1
	IBV_QPS_RTR  = 2
	IBV_QPS_RTS  = 3

	IBV_QP_STATE        = 1
	IBV_QP_ACCESS_FLAGS = 8
	IBV_QP_PKEY_INDEX   = 16
	IBV_QP_PORT         = 32
	IBV_QP_AV           = 128
	IBV_QP_PATH_MTU     = 256
	IBV_QP_RQ_PSN       = 4096
	IBV_QP_SQ_PSN       = 65536
	IBV_QP_DEST_QPN     = 1048576

	IBV_MTU_1024 = 3

	IBV_WR_RDMA_WRITE = 0
	IBV_WR_SEND       = 2
	IBV_SEND_SIGNALED = 2

	IBV_WC_SUCCESS = 0
)

Variables

View Source
var (
	// ErrNoDevice reports that no RDMA device matched the requested operation.
	ErrNoDevice = errors.New("rdma: no device")

	// ErrSymbolUnavailable reports that an RDMA provider symbol is unavailable.
	ErrSymbolUnavailable = errors.New("rdma: symbol unavailable")

	// ErrNilInput reports a nil handle or pointer passed before a provider call.
	ErrNilInput = errors.New("rdma: nil input")

	// ErrNilProviderResult reports a provider call that returned a nil handle.
	ErrNilProviderResult = errors.New("rdma: nil provider result")

	// ErrNegativeProviderReturn reports a provider call that returned a negative status.
	ErrNegativeProviderReturn = errors.New("rdma: negative provider return")

	// ErrProviderStatus reports a provider call that returned a non-zero status.
	ErrProviderStatus = errors.New("rdma: provider status")

	// ErrProviderTimeout reports a bounded provider subprocess that timed out.
	ErrProviderTimeout = errors.New("rdma: provider timeout")

	// ErrUnsupportedOperation reports an RDMA operation the provider does not support.
	ErrUnsupportedOperation = errors.New("rdma: unsupported operation")
)

Functions

func Available

func Available() bool

Available reports whether librdma and the generated probe symbols are available.

func ErrnoName added in v0.6.11

func ErrnoName(errno int) string

ErrnoName returns the symbolic name for common Apple RDMA errno values.

func ErrnoText added in v0.6.11

func ErrnoText(errno int) string

ErrnoText returns a compact name for common Apple RDMA errno values.

func IbvAckCqEvents added in v0.6.11

func IbvAckCqEvents(cq RDMACQ, nevents uint32) error

IbvAckCqEvents acknowledges completion events returned by IbvGetCqEvent.

func IbvCloseDevice added in v0.6.4

func IbvCloseDevice(context RDMAContext) (int, error)

IbvCloseDevice.

func IbvCompChannelFD added in v0.6.11

func IbvCompChannelFD(channel RDMACompChannel) int

IbvCompChannelFD returns the file descriptor stored in channel.

func IbvDeallocPd added in v0.6.4

func IbvDeallocPd(pd RDMAPD) (int, error)

IbvDeallocPd.

func IbvDeregMr added in v0.6.4

func IbvDeregMr(mr RDMAMR) (int, error)

IbvDeregMr.

func IbvDestroyCompChannel added in v0.6.11

func IbvDestroyCompChannel(channel RDMACompChannel) (int, error)

IbvDestroyCompChannel destroys a completion event channel.

func IbvDestroyCq added in v0.6.4

func IbvDestroyCq(cq RDMACQ) (int, error)

IbvDestroyCq.

func IbvDestroyQp added in v0.6.4

func IbvDestroyQp(qp RDMAQP) (int, error)

IbvDestroyQp.

func IbvFreeDeviceList added in v0.6.4

func IbvFreeDeviceList(list RDMADeviceList) error

IbvFreeDeviceList.

func IbvGetCqEvent added in v0.6.11

func IbvGetCqEvent(channel RDMACompChannel, cq *RDMACQ, cqContext *uintptr) (int, error)

IbvGetCqEvent reads the next completion event from channel.

func IbvGetDeviceName added in v0.6.4

func IbvGetDeviceName(device RDMADevice) (uintptr, error)

IbvGetDeviceName.

func IbvModifyQp added in v0.6.4

func IbvModifyQp(qp RDMAQP, attr uintptr, attr_mask int) (int, error)

IbvModifyQp.

func IbvModifyQpAttr added in v0.6.11

func IbvModifyQpAttr(qp RDMAQP, attr *IbvQPAttr, attrMask int) (int, error)

IbvModifyQpAttr calls ibv_modify_qp with a typed attr pointer.

func IbvQueryDevice added in v0.6.4

func IbvQueryDevice(context RDMAContext, device_attr uintptr) (int, error)

IbvQueryDevice.

func IbvQueryDeviceBytes added in v0.6.11

func IbvQueryDeviceBytes(context RDMAContext, buf []byte) (int, error)

IbvQueryDeviceBytes calls ibv_query_device with a byte buffer.

func IbvQueryGid added in v0.6.4

func IbvQueryGid(context RDMAContext, port_num uint8, index int, gid uintptr) (int, error)

IbvQueryGid.

func IbvQueryGidInto added in v0.6.11

func IbvQueryGidInto(context RDMAContext, portNum uint8, index int, gid *IbvGID) (int, error)

IbvQueryGidInto calls ibv_query_gid with a typed GID pointer.

func IbvQueryPort added in v0.6.4

func IbvQueryPort(context RDMAContext, port_num uint8, port_attr uintptr) (int, error)

IbvQueryPort.

func IbvQueryPortAttr added in v0.6.11

func IbvQueryPortAttr(context RDMAContext, portNum uint8, attr *IbvPortAttr) (int, error)

IbvQueryPortAttr calls ibv_query_port with a typed port-attr pointer.

func IbvReqNotifyCq added in v0.6.11

func IbvReqNotifyCq(cq RDMACQ, solicitedOnly int) (int, error)

IbvReqNotifyCq requests a completion notification for cq.

func Ibv_close_device

func Ibv_close_device(context RDMAContext) (int, error)

Ibv_close_device is kept for callers generated against the earlier RDMA names.

func Ibv_dealloc_pd

func Ibv_dealloc_pd(pd RDMAPD) (int, error)

Ibv_dealloc_pd is kept for callers generated against the earlier RDMA names.

func Ibv_dereg_mr

func Ibv_dereg_mr(mr RDMAMR) (int, error)

Ibv_dereg_mr is kept for callers generated against the earlier RDMA names.

func Ibv_destroy_cq

func Ibv_destroy_cq(cq RDMACQ) (int, error)

Ibv_destroy_cq is kept for callers generated against the earlier RDMA names.

func Ibv_destroy_qp

func Ibv_destroy_qp(qp RDMAQP) (int, error)

Ibv_destroy_qp is kept for callers generated against the earlier RDMA names.

func Ibv_free_device_list

func Ibv_free_device_list(list RDMADeviceList) error

Ibv_free_device_list is kept for callers generated against the earlier RDMA names.

func Ibv_get_device_name

func Ibv_get_device_name(device RDMADevice) (uintptr, error)

Ibv_get_device_name is kept for callers generated against the earlier RDMA names.

func Ibv_modify_qp

func Ibv_modify_qp(qp RDMAQP, attr uintptr, attrMask int) (int, error)

Ibv_modify_qp is kept for callers generated against the earlier RDMA names.

func Ibv_mr_lkey

func Ibv_mr_lkey(mr RDMAMR) uint32

func Ibv_mr_rkey

func Ibv_mr_rkey(mr RDMAMR) uint32

func Ibv_poll_cq

func Ibv_poll_cq(cq RDMACQ, numEntries int, wc *IbvWC) (int, error)

Ibv_poll_cq calls the SDK inline ibv_poll_cq wrapper through ibv_context_ops.

func Ibv_post_recv

func Ibv_post_recv(qp RDMAQP, wr *IbvRecvWR, badWR **IbvRecvWR) (int, error)

Ibv_post_recv calls the SDK inline ibv_post_recv wrapper through ibv_context_ops.

func Ibv_post_send

func Ibv_post_send(qp RDMAQP, wr *IbvSendWR, badWR **IbvSendWR) (int, error)

Ibv_post_send calls the SDK inline ibv_post_send wrapper through ibv_context_ops.

func Ibv_qp_num

func Ibv_qp_num(qp RDMAQP) uint32

func Ibv_query_device

func Ibv_query_device(context RDMAContext, deviceAttr uintptr) (int, error)

Ibv_query_device is kept for callers generated against the earlier RDMA names.

func Ibv_query_gid

func Ibv_query_gid(context RDMAContext, portNum uint8, index int, gid uintptr) (int, error)

Ibv_query_gid is kept for callers generated against the earlier RDMA names.

func Ibv_query_port

func Ibv_query_port(context RDMAContext, portNum uint8, portAttr uintptr) (int, error)

Ibv_query_port is kept for callers generated against the earlier RDMA names.

func NewModifyQPError added in v0.6.11

func NewModifyQPError(qp RDMAQP, attr *IbvQPAttr, attrMask int, rc int, err error) error

NewModifyQPError formats a failed ibv_modify_qp operation.

func QPAttrMaskNames added in v0.6.11

func QPAttrMaskNames(mask int) []string

func QPStateName added in v0.6.11

func QPStateName(state int32) string

Types

type Device

type Device struct {
	Handle RDMADevice
	Name   string
	// contains filtered or unexported fields
}

Device describes an RDMA device returned by Devices.

func Devices

func Devices() ([]Device, error)

Devices returns the RDMA devices currently reported by librdma.

It only calls exported lifecycle/probe symbols. It does not enable RDMA and may return an empty slice on systems where RDMA over Thunderbolt is disabled.

func (Device) Open added in v0.6.11

func (d Device) Open() (RDMAContext, error)

Open opens d with ibv_open_device and keeps the owning list alive for the duration of the provider call.

type DeviceList added in v0.6.11

type DeviceList struct {
	// contains filtered or unexported fields
}

DeviceList owns an ibv_get_device_list result.

Device handles returned by DeviceList.Devices remain valid until Close is called. Open devices before closing the list.

func OpenDeviceList added in v0.6.11

func OpenDeviceList() (*DeviceList, error)

OpenDeviceList returns the RDMA device list currently reported by librdma.

func (*DeviceList) Close added in v0.6.11

func (l *DeviceList) Close() error

Close releases the underlying device list. It is safe to call Close more than once.

func (*DeviceList) Devices added in v0.6.11

func (l *DeviceList) Devices() []Device

Devices returns a copy of the devices in the list.

type FailureClass added in v0.6.11

type FailureClass string

FailureClass identifies the provider-boundary failure class.

const (
	FailureNoDevice               FailureClass = "no_device"
	FailureSymbolUnavailable      FailureClass = "symbol_unavailable"
	FailureNilInput               FailureClass = "nil_input"
	FailureNilProviderResult      FailureClass = "nil_provider_result"
	FailureNegativeProviderReturn FailureClass = "negative_provider_return"
	FailureProviderStatus         FailureClass = "provider_status"
	FailureProviderTimeout        FailureClass = "provider_timeout"
	FailureUnsupportedOperation   FailureClass = "unsupported_operation"
)

type IbvAHAttr

type IbvAHAttr struct {
	GRH         IbvGlobalRoute
	DLID        uint16
	SL          uint8
	SrcPathBits uint8
	StaticRate  uint8
	IsGlobal    uint8
	PortNum     uint8
	// contains filtered or unexported fields
}

IbvAHAttr matches struct ibv_ah_attr.

type IbvCQPoller

type IbvCQPoller struct {
	// contains filtered or unexported fields
}

func NewIbvCQPoller

func NewIbvCQPoller(cq RDMACQ) (IbvCQPoller, error)

func (IbvCQPoller) Poll

func (p IbvCQPoller) Poll(numEntries int, wc *IbvWC) int

type IbvGID

type IbvGID [16]byte

IbvGID is the raw 16-byte representation of union ibv_gid.

type IbvGlobalRoute

type IbvGlobalRoute struct {
	DGID         IbvGID
	FlowLabel    uint32
	SGIDIndex    uint8
	HopLimit     uint8
	TrafficClass uint8
	// contains filtered or unexported fields
}

IbvGlobalRoute matches struct ibv_global_route.

type IbvPortAttr

type IbvPortAttr struct {
	State         int32
	MaxMTU        int32
	ActiveMTU     int32
	GIDTblLen     int32
	PortCapFlags  uint32
	MaxMsgSZ      uint32
	BadPKeyCntr   uint32
	QKeyViolCntr  uint32
	PKeyTblLen    uint16
	LID           uint16
	SMLID         uint16
	LMC           uint8
	MaxVLNum      uint8
	SMSL          uint8
	SubnetTimeout uint8
	InitTypeReply uint8
	ActiveWidth   uint8
	ActiveSpeed   uint8
	PhysState     uint8
	LinkLayer     uint8
	Flags         uint8
	PortCapFlags2 uint16
	// contains filtered or unexported fields
}

IbvPortAttr matches struct ibv_port_attr.

type IbvQPAttr

type IbvQPAttr struct {
	QPState          int32
	CurQPState       int32
	PathMTU          int32
	PathMigState     int32
	QKey             uint32
	RQPSN            uint32
	SQPSN            uint32
	DestQPNum        uint32
	QPAccessFlags    int32
	Cap              IbvQPCap
	AHAttr           IbvAHAttr
	AltAHAttr        IbvAHAttr
	PKeyIndex        uint16
	AltPKeyIndex     uint16
	EnSQDAsyncNotify uint8
	SQDraining       uint8
	MaxRDAtomic      uint8
	MaxDestRDAtomic  uint8
	MinRNRTimer      uint8
	PortNum          uint8
	Timeout          uint8
	RetryCnt         uint8
	RNRetry          uint8
	AltPortNum       uint8
	AltTimeout       uint8

	RateLimit uint32
	// contains filtered or unexported fields
}

IbvQPAttr matches the fields commonly used with ibv_modify_qp.

type IbvQPCap

type IbvQPCap struct {
	MaxSendWR     uint32
	MaxRecvWR     uint32
	MaxSendSGE    uint32
	MaxRecvSGE    uint32
	MaxInlineData uint32
}

IbvQPCap matches struct ibv_qp_cap.

type IbvQPInitAttr

type IbvQPInitAttr struct {
	QPContext uintptr
	SendCQ    RDMACQ
	RecvCQ    RDMACQ
	SRQ       uintptr
	Cap       IbvQPCap
	QPType    int32
	SQSigAll  int32
}

IbvQPInitAttr matches struct ibv_qp_init_attr.

type IbvQPPoster

type IbvQPPoster struct {
	// contains filtered or unexported fields
}

func NewIbvQPPoster

func NewIbvQPPoster(qp RDMAQP) (IbvQPPoster, error)

func (IbvQPPoster) PostRecv

func (p IbvQPPoster) PostRecv(wr *IbvRecvWR, badWR **IbvRecvWR) int

func (IbvQPPoster) PostSend

func (p IbvQPPoster) PostSend(wr *IbvSendWR, badWR **IbvSendWR) int

type IbvRecvWR

type IbvRecvWR struct {
	WRID   uint64
	Next   *IbvRecvWR
	SGList *IbvSGE
	NumSGE int32
	// contains filtered or unexported fields
}

IbvRecvWR matches struct ibv_recv_wr.

type IbvSGE

type IbvSGE struct {
	Addr   uint64
	Length uint32
	LKey   uint32
}

IbvSGE matches struct ibv_sge.

type IbvSendWR

type IbvSendWR struct {
	WRID      uint64
	Next      *IbvSendWR
	SGList    *IbvSGE
	NumSGE    int32
	Opcode    int32
	SendFlags int32
	ImmData   uint32
	WR        [32]byte
	QPType    [8]byte
	BindMW    [48]byte
}

IbvSendWR matches struct ibv_send_wr for send operations.

type IbvWC

type IbvWC struct {
	WRID         uint64
	Status       int32
	Opcode       int32
	VendorErr    uint32
	ByteLen      uint32
	ImmData      uint32
	QPNum        uint32
	SrcQP        uint32
	WCFlags      int32
	PKeyIndex    uint16
	SLID         uint16
	SL           uint8
	DLIDPathBits uint8
	PortNum      uint8
	// contains filtered or unexported fields
}

IbvWC matches struct ibv_wc.

type ModifyQPError added in v0.6.11

type ModifyQPError struct {
	Transition string
	Device     string
	QPN        uint32
	Mask       int
	Attr       IbvQPAttr
	Return     int
	Cause      error
}

ModifyQPError describes a failed ibv_modify_qp transition.

func (*ModifyQPError) Error added in v0.6.11

func (e *ModifyQPError) Error() string

func (*ModifyQPError) Unwrap added in v0.6.11

func (e *ModifyQPError) Unwrap() error

type ProviderError added in v0.6.11

type ProviderError struct {
	Operation   string
	Device      string
	Context     RDMAContext
	ContextOpen bool
	Failure     FailureClass
	Input       string
	Result      string
	Return      int64
	ReturnSet   bool
	Errno       int
	ErrnoSet    bool
	Cause       error
}

ProviderError describes an RDMA provider-boundary failure.

Operation is the ibverbs operation. Device is set when the package can tie a context back to a named RDMA device. ContextOpen reports whether the failure happened after an RDMA context had been opened.

func (*ProviderError) Error added in v0.6.11

func (e *ProviderError) Error() string

func (*ProviderError) Is added in v0.6.11

func (e *ProviderError) Is(target error) bool

func (*ProviderError) ResourceExhaustionHint added in v0.6.11

func (e *ProviderError) ResourceExhaustionHint() string

ResourceExhaustionHint returns an operator hint for failures that can indicate the Apple Thunderbolt RDMA per-boot resource exhaustion pattern.

func (*ProviderError) Unwrap added in v0.6.11

func (e *ProviderError) Unwrap() error

type RDMACQ

type RDMACQ = uintptr

func IbvCreateCq added in v0.6.4

func IbvCreateCq(context RDMAContext, cqe int, cq_context uintptr, channel uintptr, comp_vector int) (RDMACQ, error)

IbvCreateCq.

func Ibv_create_cq

func Ibv_create_cq(context RDMAContext, cqe int, cqContext uintptr, channel uintptr, compVector int) (RDMACQ, error)

Ibv_create_cq is kept for callers generated against the earlier RDMA names.

type RDMACompChannel added in v0.6.11

type RDMACompChannel = uintptr

RDMACompChannel is an ibv_comp_channel handle.

func IbvCQChannel added in v0.6.11

func IbvCQChannel(cq RDMACQ) RDMACompChannel

IbvCQChannel returns the completion channel associated with cq, if any.

func IbvCreateCompChannel added in v0.6.11

func IbvCreateCompChannel(context RDMAContext) (RDMACompChannel, error)

IbvCreateCompChannel creates a completion event channel for context.

type RDMAContext

type RDMAContext = uintptr

func IbvOpenDevice added in v0.6.4

func IbvOpenDevice(device RDMADevice) (RDMAContext, error)

IbvOpenDevice.

func Ibv_open_device

func Ibv_open_device(device RDMADevice) (RDMAContext, error)

Ibv_open_device is kept for callers generated against the earlier RDMA names.

type RDMADevice

type RDMADevice = uintptr

type RDMADeviceList

type RDMADeviceList = uintptr

func IbvGetDeviceList added in v0.6.4

func IbvGetDeviceList(num_devices uintptr) (RDMADeviceList, error)

IbvGetDeviceList.

func Ibv_get_device_list

func Ibv_get_device_list(numDevices uintptr) (RDMADeviceList, error)

Ibv_get_device_list is kept for callers generated against the earlier RDMA names.

type RDMAMR

type RDMAMR = uintptr

func IbvRegMr added in v0.6.4

func IbvRegMr(pd RDMAPD, addr uintptr, length uintptr, access int) (RDMAMR, error)

IbvRegMr.

func Ibv_reg_mr

func Ibv_reg_mr(pd RDMAPD, addr uintptr, length uintptr, access int) (RDMAMR, error)

Ibv_reg_mr is kept for callers generated against the earlier RDMA names.

type RDMAPD

type RDMAPD = uintptr

func IbvAllocPd added in v0.6.4

func IbvAllocPd(context RDMAContext) (RDMAPD, error)

IbvAllocPd.

func Ibv_alloc_pd

func Ibv_alloc_pd(context RDMAContext) (RDMAPD, error)

Ibv_alloc_pd is kept for callers generated against the earlier RDMA names.

type RDMAQP

type RDMAQP = uintptr

func IbvCreateQp added in v0.6.4

func IbvCreateQp(pd RDMAPD, qp_init_attr uintptr) (RDMAQP, error)

IbvCreateQp.

func IbvCreateQpAttr added in v0.6.11

func IbvCreateQpAttr(pd RDMAPD, attr *IbvQPInitAttr) (RDMAQP, error)

IbvCreateQpAttr calls ibv_create_qp with a typed init-attr pointer.

func Ibv_create_qp

func Ibv_create_qp(pd RDMAPD, qpInitAttr uintptr) (RDMAQP, error)

Ibv_create_qp is kept for callers generated against the earlier RDMA names.

type Resources added in v0.6.11

type Resources struct {
	Context RDMAContext
	PD      RDMAPD
	MR      RDMAMR
	CQ      RDMACQ
	QP      RDMAQP
}

Resources owns a simple ibverbs resource chain.

Close tears resources down in reverse dependency order: QP, MR, CQ, PD, then context. Zero handles are ignored, and handles are cleared before provider teardown to make repeated Close calls harmless.

func (*Resources) Close added in v0.6.11

func (r *Resources) Close() error

Close releases the resources in r.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL