Documentation
¶
Overview ¶
Package rdma provides Go bindings for the rdma framework.
Code generated from Apple documentation. DO NOT EDIT.
Index ¶
- Constants
- Variables
- func Available() bool
- func ErrnoName(errno int) string
- func ErrnoText(errno int) string
- func IbvAckCqEvents(cq RDMACQ, nevents uint32) error
- func IbvCloseDevice(context RDMAContext) (int, error)
- func IbvCompChannelFD(channel RDMACompChannel) int
- func IbvDeallocPd(pd RDMAPD) (int, error)
- func IbvDeregMr(mr RDMAMR) (int, error)
- func IbvDestroyCompChannel(channel RDMACompChannel) (int, error)
- func IbvDestroyCq(cq RDMACQ) (int, error)
- func IbvDestroyQp(qp RDMAQP) (int, error)
- func IbvFreeDeviceList(list RDMADeviceList) error
- func IbvGetCqEvent(channel RDMACompChannel, cq *RDMACQ, cqContext *uintptr) (int, error)
- func IbvGetDeviceName(device RDMADevice) (uintptr, error)
- func IbvModifyQp(qp RDMAQP, attr uintptr, attr_mask int) (int, error)
- func IbvModifyQpAttr(qp RDMAQP, attr *IbvQPAttr, attrMask int) (int, error)
- func IbvQueryDevice(context RDMAContext, device_attr uintptr) (int, error)
- func IbvQueryDeviceBytes(context RDMAContext, buf []byte) (int, error)
- func IbvQueryGid(context RDMAContext, port_num uint8, index int, gid uintptr) (int, error)
- func IbvQueryGidInto(context RDMAContext, portNum uint8, index int, gid *IbvGID) (int, error)
- func IbvQueryPort(context RDMAContext, port_num uint8, port_attr uintptr) (int, error)
- func IbvQueryPortAttr(context RDMAContext, portNum uint8, attr *IbvPortAttr) (int, error)
- func IbvReqNotifyCq(cq RDMACQ, solicitedOnly int) (int, error)
- func Ibv_close_device(context RDMAContext) (int, error)
- func Ibv_dealloc_pd(pd RDMAPD) (int, error)
- func Ibv_dereg_mr(mr RDMAMR) (int, error)
- func Ibv_destroy_cq(cq RDMACQ) (int, error)
- func Ibv_destroy_qp(qp RDMAQP) (int, error)
- func Ibv_free_device_list(list RDMADeviceList) error
- func Ibv_get_device_name(device RDMADevice) (uintptr, error)
- func Ibv_modify_qp(qp RDMAQP, attr uintptr, attrMask int) (int, error)
- func Ibv_mr_lkey(mr RDMAMR) uint32
- func Ibv_mr_rkey(mr RDMAMR) uint32
- func Ibv_poll_cq(cq RDMACQ, numEntries int, wc *IbvWC) (int, error)
- func Ibv_post_recv(qp RDMAQP, wr *IbvRecvWR, badWR **IbvRecvWR) (int, error)
- func Ibv_post_send(qp RDMAQP, wr *IbvSendWR, badWR **IbvSendWR) (int, error)
- func Ibv_qp_num(qp RDMAQP) uint32
- func Ibv_query_device(context RDMAContext, deviceAttr uintptr) (int, error)
- func Ibv_query_gid(context RDMAContext, portNum uint8, index int, gid uintptr) (int, error)
- func Ibv_query_port(context RDMAContext, portNum uint8, portAttr uintptr) (int, error)
- func NewModifyQPError(qp RDMAQP, attr *IbvQPAttr, attrMask int, rc int, err error) error
- func QPAttrMaskNames(mask int) []string
- func QPStateName(state int32) string
- type Device
- type DeviceList
- type FailureClass
- type IbvAHAttr
- type IbvCQPoller
- type IbvGID
- type IbvGlobalRoute
- type IbvPortAttr
- type IbvQPAttr
- type IbvQPCap
- type IbvQPInitAttr
- type IbvQPPoster
- type IbvRecvWR
- type IbvSGE
- type IbvSendWR
- type IbvWC
- type ModifyQPError
- type ProviderError
- type RDMACQ
- type RDMACompChannel
- type RDMAContext
- type RDMADevice
- type RDMADeviceList
- type RDMAMR
- type RDMAPD
- type RDMAQP
- type Resources
Constants ¶
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 ¶
var ( // ErrNoDevice reports that no RDMA device matched the requested operation. ErrNoDevice = errors.New("rdma: no device") 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
ErrnoName returns the symbolic name for common Apple RDMA errno values.
func ErrnoText ¶ added in v0.6.11
ErrnoText returns a compact name for common Apple RDMA errno values.
func IbvAckCqEvents ¶ added in v0.6.11
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 IbvDestroyCompChannel ¶ added in v0.6.11
func IbvDestroyCompChannel(channel RDMACompChannel) (int, error)
IbvDestroyCompChannel destroys a completion event channel.
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
IbvModifyQp.
func IbvModifyQpAttr ¶ added in v0.6.11
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
IbvQueryGid.
func IbvQueryGidInto ¶ added in v0.6.11
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
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 ¶
Ibv_dealloc_pd is kept for callers generated against the earlier RDMA names.
func Ibv_dereg_mr ¶
Ibv_dereg_mr is kept for callers generated against the earlier RDMA names.
func Ibv_destroy_cq ¶
Ibv_destroy_cq is kept for callers generated against the earlier RDMA names.
func Ibv_destroy_qp ¶
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 ¶
Ibv_modify_qp is kept for callers generated against the earlier RDMA names.
func Ibv_mr_lkey ¶
func Ibv_mr_rkey ¶
func Ibv_poll_cq ¶
Ibv_poll_cq calls the SDK inline ibv_poll_cq wrapper through ibv_context_ops.
func Ibv_post_recv ¶
Ibv_post_recv calls the SDK inline ibv_post_recv wrapper through ibv_context_ops.
func Ibv_post_send ¶
Ibv_post_send calls the SDK inline ibv_post_send wrapper through ibv_context_ops.
func Ibv_qp_num ¶
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 ¶
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
NewModifyQPError formats a failed ibv_modify_qp operation.
func QPAttrMaskNames ¶ added in v0.6.11
func QPStateName ¶ added in v0.6.11
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 ¶
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" 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)
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)
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 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 RDMAPD ¶
type RDMAPD = uintptr
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
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.
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.