
device -> active config -> claimed interface -> endpoints. Device can have at most one active config. A config can have multiple claimed interfaces, each with a specific alt setting. An interface with an alt setting defines a list of endpoints.
47 lines
1.6 KiB
Go
47 lines
1.6 KiB
Go
// Copyright 2013 Google Inc. All rights reserved.
|
|
// Copyright 2016 the gousb Authors. All rights reserved.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package usb
|
|
|
|
import "fmt"
|
|
|
|
// Descriptor is a representation of a USB device descriptor.
|
|
type Descriptor struct {
|
|
// Bus information
|
|
Bus uint8 // The bus on which the device was detected
|
|
Address uint8 // The address of the device on the bus
|
|
|
|
// Version information
|
|
Spec BCD // USB Specification Release Number
|
|
Device BCD // The device version
|
|
|
|
// Product information
|
|
Vendor ID // The Vendor identifer
|
|
Product ID // The Product identifier
|
|
|
|
// Protocol information
|
|
Class Class // The class of this device
|
|
SubClass Class // The sub-class (within the class) of this device
|
|
Protocol Protocol // The protocol (within the sub-class) of this device
|
|
|
|
// Configuration information
|
|
Configs []ConfigInfo
|
|
}
|
|
|
|
// String represents a human readable representation of the device in the descriptor.
|
|
func (d *Descriptor) String() string {
|
|
return fmt.Sprintf("vid=%s,pid=%s,bus=%d,addr=%d", d.Vendor, d.Product, d.Bus, d.Address)
|
|
}
|