libxr  1.0
Want to be the best embedded framework
Loading...
Searching...
No Matches
LibXR::USB::BosManager Class Reference

BOS 管理器:能力收集、BOS 描述符拼装、Vendor 请求链式分发 BOS manager: capability collection, descriptor building, vendor dispatch. More...

#include <bos.hpp>

Collaboration diagram for LibXR::USB::BosManager:
[legend]

Public Member Functions

 BosManager (size_t buffer_size, size_t cap_num)
 构造函数 / Constructor
 
 BosManager (const BosManager &)=delete
 
BosManageroperator= (const BosManager &)=delete
 
void ClearCapabilities ()
 清空已注册能力 / Clear registered capabilities
 
bool AddCapability (BosCapability *cap)
 添加能力 / Add capability
 
ConstRawData GetBosDescriptor ()
 构建 BOS 描述符(BOS 头 + 能力块) Build BOS descriptor (header + blocks).
 
ErrorCode ProcessVendorRequest (bool in_isr, const SetupPacket *setup, BosVendorResult &result)
 Vendor 请求分发 / Vendor request dispatch.
 

Private Attributes

size_t cap_capacity_ = 0
 能力指针容量 / Capability pointer capacity
 
BosCapability ** caps_ = nullptr
 能力指针表 / Capability pointer table
 
size_t count_ = 0
 已注册能力数量 / Registered capability count
 
RawData bos_buffer_ = {nullptr, 0}
 BOS 缓冲区 / BOS buffer.
 

Detailed Description

BOS 管理器:能力收集、BOS 描述符拼装、Vendor 请求链式分发 BOS manager: capability collection, descriptor building, vendor dispatch.

Note
仅拥有内部数组/缓冲区,不拥有 BosCapability 对象。

Definition at line 112 of file bos.hpp.

Constructor & Destructor Documentation

◆ BosManager()

LibXR::USB::BosManager::BosManager ( size_t buffer_size,
size_t cap_num )
inline

构造函数 / Constructor

Parameters
buffer_sizeBOS 描述符缓冲区大小 / BOS buffer size
cap_num能力指针容量 / Capability pointer capacity

Definition at line 121 of file bos.hpp.

122 : cap_capacity_(cap_num),
123 caps_(new BosCapability*[cap_num]),
124 bos_buffer_({new uint8_t[buffer_size], buffer_size})
125 {
126 }
size_t cap_capacity_
能力指针容量 / Capability pointer capacity
Definition bos.hpp:267
BosCapability ** caps_
能力指针表 / Capability pointer table
Definition bos.hpp:268
RawData bos_buffer_
BOS 缓冲区 / BOS buffer.
Definition bos.hpp:271

Member Function Documentation

◆ AddCapability()

bool LibXR::USB::BosManager::AddCapability ( BosCapability * cap)
inline

添加能力 / Add capability

Parameters
cap能力指针 / Capability pointer
Returns
true:成功;false:失败 / true: success; false: failure

Definition at line 142 of file bos.hpp.

143 {
144 ASSERT(bos_buffer_.addr_);
145 ASSERT(cap != nullptr);
146 ASSERT(count_ < cap_capacity_);
147
148 caps_[count_++] = cap;
149 return true;
150 }
void * addr_
数据存储地址。 The storage address of the data.
size_t count_
已注册能力数量 / Registered capability count
Definition bos.hpp:269

◆ ClearCapabilities()

void LibXR::USB::BosManager::ClearCapabilities ( )
inline

清空已注册能力 / Clear registered capabilities

Definition at line 134 of file bos.hpp.

134{ count_ = 0; }

◆ GetBosDescriptor()

ConstRawData LibXR::USB::BosManager::GetBosDescriptor ( )
inline

构建 BOS 描述符(BOS 头 + 能力块) Build BOS descriptor (header + blocks).

Returns
ConstRawData BOS 描述符数据 / BOS descriptor bytes

Definition at line 158 of file bos.hpp.

159 {
160 ASSERT(bos_buffer_.addr_);
161
162 bool has_usb2_ext = false;
163 for (size_t i = 0; i < count_; ++i)
164 {
165 ConstRawData blk = caps_[i]->GetCapabilityDescriptor();
166 ASSERT(blk.addr_ != nullptr);
167 ASSERT(blk.size_ >= 3);
168
169 const uint8_t* p = reinterpret_cast<const uint8_t*>(blk.addr_);
170 if (p[1] == DESCRIPTOR_TYPE_DEVICE_CAPABILITY &&
171 p[2] == DEV_CAPABILITY_TYPE_USB20EXT)
172 {
173 has_usb2_ext = true;
174 }
175 }
176
177 static constexpr uint8_t USB2_EXT_CAP[USB2_EXT_CAP_SIZE] = {7, 0x10, 0x02, 0x00,
178 0x00, 0x00, 0x00};
179 const bool NEED_AUTO_USB2_EXT = !has_usb2_ext;
180
181 size_t total = BOS_HEADER_SIZE;
182 for (size_t i = 0; i < count_; ++i)
183 {
184 ConstRawData blk = caps_[i]->GetCapabilityDescriptor();
185 ASSERT(blk.addr_ != nullptr);
186 ASSERT(blk.size_ >= 1);
187 total += blk.size_;
188 }
189 if (NEED_AUTO_USB2_EXT)
190 {
191 total += sizeof(USB2_EXT_CAP);
192 }
193
194 ASSERT(total <= bos_buffer_.size_);
195 ASSERT(total <= 0xFFFF);
196
197 auto buffer = reinterpret_cast<uint8_t*>(bos_buffer_.addr_);
198
199 buffer[0] = static_cast<uint8_t>(BOS_HEADER_SIZE);
200 buffer[1] = DESCRIPTOR_TYPE_BOS;
201 buffer[2] = static_cast<uint8_t>(total & 0xFF);
202 buffer[3] = static_cast<uint8_t>((total >> 8) & 0xFF);
203 buffer[4] = static_cast<uint8_t>(count_ + (NEED_AUTO_USB2_EXT ? 1 : 0));
204
205 size_t offset = BOS_HEADER_SIZE;
206
207 for (size_t i = 0; i < count_; ++i)
208 {
209 ConstRawData blk = caps_[i]->GetCapabilityDescriptor();
210 ASSERT(offset + blk.size_ <= bos_buffer_.size_);
211
212 LibXR::Memory::FastCopy(&buffer[offset], blk.addr_, blk.size_);
213 offset += blk.size_;
214 }
215
216 if (NEED_AUTO_USB2_EXT)
217 {
218 ASSERT(offset + sizeof(USB2_EXT_CAP) <= bos_buffer_.size_);
219 LibXR::Memory::FastCopy(&buffer[offset], USB2_EXT_CAP, sizeof(USB2_EXT_CAP));
220 offset += sizeof(USB2_EXT_CAP);
221 }
222
223 return {buffer, offset};
224 }
static void FastCopy(void *dst, const void *src, size_t size)
快速内存拷贝 / Fast memory copy
Definition libxr_mem.cpp:5
size_t size_
数据大小(字节)。 The size of the data (in bytes).
virtual ConstRawData GetCapabilityDescriptor() const =0
返回能力块(不含 BOS 头) Return capability block (without BOS header).

◆ ProcessVendorRequest()

ErrorCode LibXR::USB::BosManager::ProcessVendorRequest ( bool in_isr,
const SetupPacket * setup,
BosVendorResult & result )
inline

Vendor 请求分发 / Vendor request dispatch.

Parameters
in_isrISR 上下文标志 / ISR context flag
setupSetup 包 / Setup packet
result输出结果 / Output result
Returns
OK:已处理;NOT_SUPPORT:无匹配;其他:匹配但失败

Definition at line 234 of file bos.hpp.

236 {
237 if (setup == nullptr)
238 {
239 return ErrorCode::ARG_ERR;
240 }
241
242 for (size_t i = 0; i < count_; ++i)
243 {
244 BosVendorResult tmp{};
245 auto ec = caps_[i]->OnVendorRequest(in_isr, setup, tmp);
246
247 if (ec == ErrorCode::NOT_SUPPORT)
248 {
249 continue;
250 }
251 if (ec != ErrorCode::OK)
252 {
253 return ec;
254 }
255 if (tmp.handled)
256 {
257 result = tmp;
258 return ErrorCode::OK;
259 }
260 return ErrorCode::FAILED;
261 }
262
264 }
virtual ErrorCode OnVendorRequest(bool, const SetupPacket *, BosVendorResult &)
处理该能力相关 Vendor 请求 / Handle vendor request for this capability
Definition bos.hpp:75
@ NOT_SUPPORT
不支持 | Not supported
@ FAILED
操作失败 | Operation failed
@ OK
操作成功 | Operation successful
@ ARG_ERR
参数错误 | Argument error

Field Documentation

◆ bos_buffer_

RawData LibXR::USB::BosManager::bos_buffer_ = {nullptr, 0}
private

BOS 缓冲区 / BOS buffer.

Definition at line 271 of file bos.hpp.

271{nullptr, 0};

◆ cap_capacity_

size_t LibXR::USB::BosManager::cap_capacity_ = 0
private

能力指针容量 / Capability pointer capacity

Definition at line 267 of file bos.hpp.

◆ caps_

BosCapability** LibXR::USB::BosManager::caps_ = nullptr
private

能力指针表 / Capability pointer table

Definition at line 268 of file bos.hpp.

◆ count_

size_t LibXR::USB::BosManager::count_ = 0
private

已注册能力数量 / Registered capability count

Definition at line 269 of file bos.hpp.


The documentation for this class was generated from the following file: