€•¿`Œsphinx.addnodes”Œdocument”“”)”}”(Œ rawsource”Œ”Œchildren”]”(Œ translations”Œ LanguagesNode”“”)”}”(hhh]”(hŒ pending_xref”“”)”}”(hhh]”Œdocutils.nodes”ŒText”“”ŒChinese (Simplified)”…””}”Œparent”hsbaŒ attributes”}”(Œids”]”Œclasses”]”Œnames”]”Œdupnames”]”Œbackrefs”]”Œ refdomain”Œstd”Œreftype”Œdoc”Œ reftarget”Œ'/translations/zh_CN/infiniband/user_mad”Œmodname”NŒ classname”NŒ refexplicit”ˆuŒtagname”hhh ubh)”}”(hhh]”hŒChinese (Traditional)”…””}”hh2sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ'/translations/zh_TW/infiniband/user_mad”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒItalian”…””}”hhFsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ'/translations/it_IT/infiniband/user_mad”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒJapanese”…””}”hhZsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ'/translations/ja_JP/infiniband/user_mad”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒKorean”…””}”hhnsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ'/translations/ko_KR/infiniband/user_mad”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒSpanish”…””}”hh‚sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ'/translations/sp_SP/infiniband/user_mad”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubeh}”(h]”h ]”h"]”h$]”h&]”Œcurrent_language”ŒEnglish”uh1h hhŒ _document”hŒsource”NŒline”NubhŒsection”“”)”}”(hhh]”(hŒtitle”“”)”}”(hŒUserspace MAD access”h]”hŒUserspace MAD access”…””}”(hh¨hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hh£hžhhŸŒA/var/lib/git/docbuild/linux/Documentation/infiniband/user_mad.rst”h Kubh¢)”}”(hhh]”(h§)”}”(hŒ Device files”h]”hŒ Device files”…””}”(hhºhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hh·hžhhŸh¶h KubhŒ block_quote”“”)”}”(hŒëEach port of each InfiniBand device has a "umad" device and an "issm" device attached. For example, a two-port HCA will have two umad devices and two issm devices, while a switch will have one device of each type (for switch port 0). ”h]”hŒ paragraph”“”)”}”(hŒêEach port of each InfiniBand device has a "umad" device and an "issm" device attached. For example, a two-port HCA will have two umad devices and two issm devices, while a switch will have one device of each type (for switch port 0).”h]”hŒòEach port of each InfiniBand device has a “umad†device and an “issm†device attached. For example, a two-port HCA will have two umad devices and two issm devices, while a switch will have one device of each type (for switch port 0).”…””}”(hhÐhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h KhhÊubah}”(h]”h ]”h"]”h$]”h&]”uh1hÈhŸh¶h Khh·hžhubeh}”(h]”Œ device-files”ah ]”h"]”Œ device files”ah$]”h&]”uh1h¡hh£hžhhŸh¶h Kubh¢)”}”(hhh]”(h§)”}”(hŒCreating MAD agents”h]”hŒCreating MAD agents”…””}”(hhïhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hhìhžhhŸh¶h KubhÉ)”}”(hX‡A MAD agent can be created by filling in a struct ib_user_mad_reg_req and then calling the IB_USER_MAD_REGISTER_AGENT ioctl on a file descriptor for the appropriate device file. If the registration request succeeds, a 32-bit id will be returned in the structure. For example:: struct ib_user_mad_reg_req req = { /* ... */ }; ret = ioctl(fd, IB_USER_MAD_REGISTER_AGENT, (char *) &req); if (!ret) my_agent = req.id; else perror("agent register"); Agents can be unregistered with the IB_USER_MAD_UNREGISTER_AGENT ioctl. Also, all agents registered through a file descriptor will be unregistered when the descriptor is closed. 2014 a new registration ioctl is now provided which allows additional fields to be provided during registration. Users of this registration call are implicitly setting the use of pkey_index (see below). ”h]”(hÏ)”}”(hXA MAD agent can be created by filling in a struct ib_user_mad_reg_req and then calling the IB_USER_MAD_REGISTER_AGENT ioctl on a file descriptor for the appropriate device file. If the registration request succeeds, a 32-bit id will be returned in the structure. For example::”h]”hXA MAD agent can be created by filling in a struct ib_user_mad_reg_req and then calling the IB_USER_MAD_REGISTER_AGENT ioctl on a file descriptor for the appropriate device file. If the registration request succeeds, a 32-bit id will be returned in the structure. For example:”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h KhhýubhŒ literal_block”“”)”}”(hŒ·struct ib_user_mad_reg_req req = { /* ... */ }; ret = ioctl(fd, IB_USER_MAD_REGISTER_AGENT, (char *) &req); if (!ret) my_agent = req.id; else perror("agent register");”h]”hŒ·struct ib_user_mad_reg_req req = { /* ... */ }; ret = ioctl(fd, IB_USER_MAD_REGISTER_AGENT, (char *) &req); if (!ret) my_agent = req.id; else perror("agent register");”…””}”hjsbah}”(h]”h ]”h"]”h$]”h&]”Œ xml:space”Œpreserve”uh1jhŸh¶h KhhýubhÏ)”}”(hŒ²Agents can be unregistered with the IB_USER_MAD_UNREGISTER_AGENT ioctl. Also, all agents registered through a file descriptor will be unregistered when the descriptor is closed.”h]”hŒ²Agents can be unregistered with the IB_USER_MAD_UNREGISTER_AGENT ioctl. Also, all agents registered through a file descriptor will be unregistered when the descriptor is closed.”…””}”(hj!hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h KhhýubhŒdefinition_list”“”)”}”(hhh]”hŒdefinition_list_item”“”)”}”(hŒË2014 a new registration ioctl is now provided which allows additional fields to be provided during registration. Users of this registration call are implicitly setting the use of pkey_index (see below). ”h]”(hŒterm”“”)”}”(hŒ2014”h]”hŒ2014”…””}”(hj<hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j:hŸh¶h K%hj6ubhŒ definition”“”)”}”(hhh]”hÏ)”}”(hŒÅa new registration ioctl is now provided which allows additional fields to be provided during registration. Users of this registration call are implicitly setting the use of pkey_index (see below).”h]”hŒÅa new registration ioctl is now provided which allows additional fields to be provided during registration. Users of this registration call are implicitly setting the use of pkey_index (see below).”…””}”(hjOhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h K"hjLubah}”(h]”h ]”h"]”h$]”h&]”uh1jJhj6ubeh}”(h]”h ]”h"]”h$]”h&]”uh1j4hŸh¶h K%hj1ubah}”(h]”h ]”h"]”h$]”h&]”uh1j/hhýubeh}”(h]”h ]”h"]”h$]”h&]”uh1hÈhŸh¶h Khhìhžhubeh}”(h]”Œcreating-mad-agents”ah ]”h"]”Œcreating mad agents”ah$]”h&]”uh1h¡hh£hžhhŸh¶h Kubh¢)”}”(hhh]”(h§)”}”(hŒReceiving MADs”h]”hŒReceiving MADs”…””}”(hj€hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hj}hžhhŸh¶h K(ubhÉ)”}”(hXŠMADs are received using read(). The receive side now supports RMPP. The buffer passed to read() must be at least one struct ib_user_mad + 256 bytes. For example: If the buffer passed is not large enough to hold the received MAD (RMPP), the errno is set to ENOSPC and the length of the buffer needed is set in mad.length. Example for normal MAD (non RMPP) reads:: struct ib_user_mad *mad; mad = malloc(sizeof *mad + 256); ret = read(fd, mad, sizeof *mad + 256); if (ret != sizeof mad + 256) { perror("read"); free(mad); } Example for RMPP reads:: struct ib_user_mad *mad; mad = malloc(sizeof *mad + 256); ret = read(fd, mad, sizeof *mad + 256); if (ret == -ENOSPC)) { length = mad.length; free(mad); mad = malloc(sizeof *mad + length); ret = read(fd, mad, sizeof *mad + length); } if (ret < 0) { perror("read"); free(mad); } In addition to the actual MAD contents, the other struct ib_user_mad fields will be filled in with information on the received MAD. For example, the remote LID will be in mad.lid. If a send times out, a receive will be generated with mad.status set to ETIMEDOUT. Otherwise when a MAD has been successfully received, mad.status will be 0. poll()/select() may be used to wait until a MAD can be read. ”h]”(hÏ)”}”(hŒ¢MADs are received using read(). The receive side now supports RMPP. The buffer passed to read() must be at least one struct ib_user_mad + 256 bytes. For example:”h]”hŒ¢MADs are received using read(). The receive side now supports RMPP. The buffer passed to read() must be at least one struct ib_user_mad + 256 bytes. For example:”…””}”(hj’hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h K*hjŽubhÏ)”}”(hŒžIf the buffer passed is not large enough to hold the received MAD (RMPP), the errno is set to ENOSPC and the length of the buffer needed is set in mad.length.”h]”hŒžIf the buffer passed is not large enough to hold the received MAD (RMPP), the errno is set to ENOSPC and the length of the buffer needed is set in mad.length.”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h K.hjŽubhÏ)”}”(hŒ)Example for normal MAD (non RMPP) reads::”h]”hŒ(Example for normal MAD (non RMPP) reads:”…””}”(hj®hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h K2hjŽubj)”}”(hŒ­struct ib_user_mad *mad; mad = malloc(sizeof *mad + 256); ret = read(fd, mad, sizeof *mad + 256); if (ret != sizeof mad + 256) { perror("read"); free(mad); }”h]”hŒ­struct ib_user_mad *mad; mad = malloc(sizeof *mad + 256); ret = read(fd, mad, sizeof *mad + 256); if (ret != sizeof mad + 256) { perror("read"); free(mad); }”…””}”hj¼sbah}”(h]”h ]”h"]”h$]”h&]”jj uh1jhŸh¶h K4hjŽubhÏ)”}”(hŒExample for RMPP reads::”h]”hŒExample for RMPP reads:”…””}”(hjÊhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h KhjŽubhÏ)”}”(hŒ´In addition to the actual MAD contents, the other struct ib_user_mad fields will be filled in with information on the received MAD. For example, the remote LID will be in mad.lid.”h]”hŒ´In addition to the actual MAD contents, the other struct ib_user_mad fields will be filled in with information on the received MAD. For example, the remote LID will be in mad.lid.”…””}”(hjæhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h KLhjŽubhÏ)”}”(hŒžIf a send times out, a receive will be generated with mad.status set to ETIMEDOUT. Otherwise when a MAD has been successfully received, mad.status will be 0.”h]”hŒžIf a send times out, a receive will be generated with mad.status set to ETIMEDOUT. Otherwise when a MAD has been successfully received, mad.status will be 0.”…””}”(hjôhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h KPhjŽubhÏ)”}”(hŒdata */ mad->hdr.id = my_agent; /* req.id from agent registration */ mad->hdr.lid = my_dest; /* in network byte order... */ /* etc. */ ret = write(fd, &mad, sizeof *mad + mad_length); if (ret != sizeof *mad + mad_length) perror("write"); ”h]”(hÏ)”}”(hŒýMADs are sent using write(). The agent ID for sending should be filled into the id field of the MAD, the destination LID should be filled into the lid field, and so on. The send side does support RMPP so arbitrary length MAD can be sent. For example::”h]”hŒüMADs are sent using write(). The agent ID for sending should be filled into the id field of the MAD, the destination LID should be filled into the lid field, and so on. The send side does support RMPP so arbitrary length MAD can be sent. For example:”…””}”(hj3hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h KYhj/ubj)”}”(hXZstruct ib_user_mad *mad; mad = malloc(sizeof *mad + mad_length); /* fill in mad->data */ mad->hdr.id = my_agent; /* req.id from agent registration */ mad->hdr.lid = my_dest; /* in network byte order... */ /* etc. */ ret = write(fd, &mad, sizeof *mad + mad_length); if (ret != sizeof *mad + mad_length) perror("write");”h]”hXZstruct ib_user_mad *mad; mad = malloc(sizeof *mad + mad_length); /* fill in mad->data */ mad->hdr.id = my_agent; /* req.id from agent registration */ mad->hdr.lid = my_dest; /* in network byte order... */ /* etc. */ ret = write(fd, &mad, sizeof *mad + mad_length); if (ret != sizeof *mad + mad_length) perror("write");”…””}”hjAsbah}”(h]”h ]”h"]”h$]”h&]”jj uh1jhŸh¶h K^hj/ubeh}”(h]”h ]”h"]”h$]”h&]”uh1hÈhŸh¶h KYhjhžhubeh}”(h]”Œ sending-mads”ah ]”h"]”Œ sending mads”ah$]”h&]”uh1h¡hh£hžhhŸh¶h KWubh¢)”}”(hhh]”(h§)”}”(hŒTransaction IDs”h]”hŒTransaction IDs”…””}”(hj`hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hj]hžhhŸh¶h KmubhÉ)”}”(hX1Users of the umad devices can use the lower 32 bits of the transaction ID field (that is, the least significant half of the field in network byte order) in MADs being sent to match request/response pairs. The upper 32 bits are reserved for use by the kernel and will be overwritten before a MAD is sent. ”h]”hÏ)”}”(hX0Users of the umad devices can use the lower 32 bits of the transaction ID field (that is, the least significant half of the field in network byte order) in MADs being sent to match request/response pairs. The upper 32 bits are reserved for use by the kernel and will be overwritten before a MAD is sent.”h]”hX0Users of the umad devices can use the lower 32 bits of the transaction ID field (that is, the least significant half of the field in network byte order) in MADs being sent to match request/response pairs. The upper 32 bits are reserved for use by the kernel and will be overwritten before a MAD is sent.”…””}”(hjrhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h Kohjnubah}”(h]”h ]”h"]”h$]”h&]”uh1hÈhŸh¶h Kohj]hžhubeh}”(h]”Œtransaction-ids”ah ]”h"]”Œtransaction ids”ah$]”h&]”uh1h¡hh£hžhhŸh¶h Kmubh¢)”}”(hhh]”(h§)”}”(hŒP_Key Index Handling”h]”hŒP_Key Index Handling”…””}”(hj‘hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hjŽhžhhŸh¶h KvubhÉ)”}”(hX¨The old ib_umad interface did not allow setting the P_Key index for MADs that are sent and did not provide a way for obtaining the P_Key index of received MADs. A new layout for struct ib_user_mad_hdr with a pkey_index member has been defined; however, to preserve binary compatibility with older applications, this new layout will not be used unless one of IB_USER_MAD_ENABLE_PKEY or IB_USER_MAD_REGISTER_AGENT2 ioctl's are called before a file descriptor is used for anything else. In September 2008, the IB_USER_MAD_ABI_VERSION will be incremented to 6, the new layout of struct ib_user_mad_hdr will be used by default, and the IB_USER_MAD_ENABLE_PKEY ioctl will be removed. ”h]”(hÏ)”}”(hXäThe old ib_umad interface did not allow setting the P_Key index for MADs that are sent and did not provide a way for obtaining the P_Key index of received MADs. A new layout for struct ib_user_mad_hdr with a pkey_index member has been defined; however, to preserve binary compatibility with older applications, this new layout will not be used unless one of IB_USER_MAD_ENABLE_PKEY or IB_USER_MAD_REGISTER_AGENT2 ioctl's are called before a file descriptor is used for anything else.”h]”hXæThe old ib_umad interface did not allow setting the P_Key index for MADs that are sent and did not provide a way for obtaining the P_Key index of received MADs. A new layout for struct ib_user_mad_hdr with a pkey_index member has been defined; however, to preserve binary compatibility with older applications, this new layout will not be used unless one of IB_USER_MAD_ENABLE_PKEY or IB_USER_MAD_REGISTER_AGENT2 ioctl’s are called before a file descriptor is used for anything else.”…””}”(hj£hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h KxhjŸubhÏ)”}”(hŒÁIn September 2008, the IB_USER_MAD_ABI_VERSION will be incremented to 6, the new layout of struct ib_user_mad_hdr will be used by default, and the IB_USER_MAD_ENABLE_PKEY ioctl will be removed.”h]”hŒÁIn September 2008, the IB_USER_MAD_ABI_VERSION will be incremented to 6, the new layout of struct ib_user_mad_hdr will be used by default, and the IB_USER_MAD_ENABLE_PKEY ioctl will be removed.”…””}”(hj±hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h K€hjŸubeh}”(h]”h ]”h"]”h$]”h&]”uh1hÈhŸh¶h KxhjŽhžhubeh}”(h]”Œp-key-index-handling”ah ]”h"]”Œp_key index handling”ah$]”h&]”uh1h¡hh£hžhhŸh¶h Kvubh¢)”}”(hhh]”(h§)”}”(hŒSetting IsSM Capability Bit”h]”hŒSetting IsSM Capability Bit”…””}”(hjÐhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hjÍhžhhŸh¶h K…ubhÉ)”}”(hX“To set the IsSM capability bit for a port, simply open the corresponding issm device file. If the IsSM bit is already set, then the open call will block until the bit is cleared (or return immediately with errno set to EAGAIN if the O_NONBLOCK flag is passed to open()). The IsSM bit will be cleared when the issm file is closed. No read, write or other operations can be performed on the issm file. ”h]”hÏ)”}”(hX’To set the IsSM capability bit for a port, simply open the corresponding issm device file. If the IsSM bit is already set, then the open call will block until the bit is cleared (or return immediately with errno set to EAGAIN if the O_NONBLOCK flag is passed to open()). The IsSM bit will be cleared when the issm file is closed. No read, write or other operations can be performed on the issm file.”h]”hX’To set the IsSM capability bit for a port, simply open the corresponding issm device file. If the IsSM bit is already set, then the open call will block until the bit is cleared (or return immediately with errno set to EAGAIN if the O_NONBLOCK flag is passed to open()). The IsSM bit will be cleared when the issm file is closed. No read, write or other operations can be performed on the issm file.”…””}”(hjâhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h K‡hjÞubah}”(h]”h ]”h"]”h$]”h&]”uh1hÈhŸh¶h K‡hjÍhžhubeh}”(h]”Œsetting-issm-capability-bit”ah ]”h"]”Œsetting issm capability bit”ah$]”h&]”uh1h¡hh£hžhhŸh¶h K…ubh¢)”}”(hhh]”(h§)”}”(hŒ /dev files”h]”hŒ /dev files”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hjþhžhhŸh¶h KubhÉ)”}”(hX6To create the appropriate character device files automatically with udev, a rule like:: KERNEL=="umad*", NAME="infiniband/%k" KERNEL=="issm*", NAME="infiniband/%k" can be used. This will create device nodes named:: /dev/infiniband/umad0 /dev/infiniband/issm0 for the first port, and so on. The InfiniBand device and port associated with these devices can be determined from the files:: /sys/class/infiniband_mad/umad0/ibdev /sys/class/infiniband_mad/umad0/port and:: /sys/class/infiniband_mad/issm0/ibdev /sys/class/infiniband_mad/issm0/port”h]”(hÏ)”}”(hŒWTo create the appropriate character device files automatically with udev, a rule like::”h]”hŒVTo create the appropriate character device files automatically with udev, a rule like:”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h K’hjubj)”}”(hŒKKERNEL=="umad*", NAME="infiniband/%k" KERNEL=="issm*", NAME="infiniband/%k"”h]”hŒKKERNEL=="umad*", NAME="infiniband/%k" KERNEL=="issm*", NAME="infiniband/%k"”…””}”hj!sbah}”(h]”h ]”h"]”h$]”h&]”jj uh1jhŸh¶h K•hjubhÏ)”}”(hŒ3can be used. This will create device nodes named::”h]”hŒ2can be used. This will create device nodes named:”…””}”(hj/hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h K˜hjubj)”}”(hŒ+/dev/infiniband/umad0 /dev/infiniband/issm0”h]”hŒ+/dev/infiniband/umad0 /dev/infiniband/issm0”…””}”hj=sbah}”(h]”h ]”h"]”h$]”h&]”jj uh1jhŸh¶h KšhjubhÏ)”}”(hŒfor the first port, and so on. The InfiniBand device and port associated with these devices can be determined from the files::”h]”hŒ~for the first port, and so on. The InfiniBand device and port associated with these devices can be determined from the files:”…””}”(hjKhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h Khjubj)”}”(hŒJ/sys/class/infiniband_mad/umad0/ibdev /sys/class/infiniband_mad/umad0/port”h]”hŒJ/sys/class/infiniband_mad/umad0/ibdev /sys/class/infiniband_mad/umad0/port”…””}”hjYsbah}”(h]”h ]”h"]”h$]”h&]”jj uh1jhŸh¶h K hjubhÏ)”}”(hŒand::”h]”hŒand:”…””}”(hjghžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÎhŸh¶h K£hjubj)”}”(hŒJ/sys/class/infiniband_mad/issm0/ibdev /sys/class/infiniband_mad/issm0/port”h]”hŒJ/sys/class/infiniband_mad/issm0/ibdev /sys/class/infiniband_mad/issm0/port”…””}”hjusbah}”(h]”h ]”h"]”h$]”h&]”jj uh1jhŸh¶h K¥hjubeh}”(h]”h ]”h"]”h$]”h&]”uh1hÈhŸh¶h K’hjþhžhubeh}”(h]”Œ dev-files”ah ]”h"]”Œ /dev files”ah$]”h&]”uh1h¡hh£hžhhŸh¶h Kubeh}”(h]”Œuserspace-mad-access”ah ]”h"]”Œuserspace mad access”ah$]”h&]”uh1h¡hhhžhhŸh¶h Kubeh}”(h]”h ]”h"]”h$]”h&]”Œsource”h¶uh1hŒcurrent_source”NŒ current_line”NŒsettings”Œdocutils.frontend”ŒValues”“”)”}”(h¦NŒ generator”NŒ datestamp”NŒ source_link”NŒ source_url”NŒ toc_backlinks”Œentry”Œfootnote_backlinks”KŒ sectnum_xform”KŒstrip_comments”NŒstrip_elements_with_classes”NŒ strip_classes”NŒ report_level”KŒ halt_level”KŒexit_status_level”KŒdebug”NŒwarning_stream”NŒ traceback”ˆŒinput_encoding”Œ utf-8-sig”Œinput_encoding_error_handler”Œstrict”Œoutput_encoding”Œutf-8”Œoutput_encoding_error_handler”j¼Œerror_encoding”Œutf-8”Œerror_encoding_error_handler”Œbackslashreplace”Œ language_code”Œen”Œrecord_dependencies”NŒconfig”NŒ id_prefix”hŒauto_id_prefix”Œid”Œ dump_settings”NŒdump_internals”NŒdump_transforms”NŒdump_pseudo_xml”NŒexpose_internals”NŒstrict_visitor”NŒ_disable_config”NŒ_source”h¶Œ _destination”NŒ _config_files”]”Œ7/var/lib/git/docbuild/linux/Documentation/docutils.conf”aŒfile_insertion_enabled”ˆŒ raw_enabled”KŒline_length_limit”M'Œpep_references”NŒ pep_base_url”Œhttps://peps.python.org/”Œpep_file_url_template”Œpep-%04d”Œrfc_references”NŒ rfc_base_url”Œ&https://datatracker.ietf.org/doc/html/”Œ tab_width”KŒtrim_footnote_reference_space”‰Œsyntax_highlight”Œlong”Œ smart_quotes”ˆŒsmartquotes_locales”]”Œcharacter_level_inline_markup”‰Œdoctitle_xform”‰Œ docinfo_xform”KŒsectsubtitle_xform”‰Œ image_loading”Œlink”Œembed_stylesheet”‰Œcloak_email_addresses”ˆŒsection_self_link”‰Œenv”NubŒreporter”NŒindirect_targets”]”Œsubstitution_defs”}”Œsubstitution_names”}”Œrefnames”}”Œrefids”}”Œnameids”}”(j–j“héhæjzjwjjjZjWj‹jˆjÊjÇjûjøjŽj‹uŒ nametypes”}”(j–‰hé‰jz‰j‰jZ‰j‹‰jʉjû‰jމuh}”(j“h£hæh·jwhìjj}jWjjˆj]jÇjŽjøjÍj‹jþuŒ footnote_refs”}”Œ citation_refs”}”Œ autofootnotes”]”Œautofootnote_refs”]”Œsymbol_footnotes”]”Œsymbol_footnote_refs”]”Œ footnotes”]”Œ citations”]”Œautofootnote_start”KŒsymbol_footnote_start”KŒ id_counter”Œ collections”ŒCounter”“”}”…”R”Œparse_messages”]”Œtransform_messages”]”Œ transformer”NŒ include_log”]”Œ decoration”Nhžhub.