2000 Microchip Technology Inc.
Preliminary
DS41124C-page 73
PIC16C745/765
10.9.3.6
Buffer Allocation
The PIC16C745/765 has 64 bytes of Dual Port RAM.
24 are used for the Buffer Descriptor Table (BDT),
leaving 40 bytes for buffers.
Endpoints 0 IN and OUT need dedicated buffers since
a setup transaction can never be NAKed. That leaves
three buffers for four possible Endpoints, but the USB
spec requires that low speed devices are only allowed
2 endpoints (USB 1.1 paragraph 5.3.1.2), where an
endpoint is a simplex connection that is defined by the
combination of Endpoint number and direction.
10.9.3.7
Vendor Specific Commands
Vendor specific commands are defined by the vendor.
These are parsed out, but are not processed. Instead,
control is passed to function CheckVendor where
they can be processed.
10.9.4
FILE PACKAGING
The software interface is packaged into four files,
designed to simplify the integration with your application.
File USB_CH9.ASM contains the interface and core
functions
needed
to
enumerate
the
bus.
DESCRIPT.ASM contains the device, config, inter-
face, endpoint and string descriptors. Both of these
files must be linked in with your application.
HIDCLASS.ASM provides some HID Class specific
functions. Currently only GetReportDescriptor is sup-
ported. Other class specific functions can be imple-
mented in a similar fashion. When a token done
interrupt determines that it’s a class specific command
on the basis that ReportType bit 6 is set, control is
passed to function ClassSpecific. If you’re working
with a different class, this is your interface between the
core functions and the class specific functions.
USB_MAIN.ASM is useful as a starting point on a new
application and as an example of how an existing
application needs to service the USB interrupt and
communicate with the core functions.
10.9.5
FUNCTION CALL REFERENCE
Interface between the Application and Protocol layer
takes place in three main functions: InitUSB, PutUSB
and GetUSB.
InitUSB should be called by the main program immedi-
ately upon power-up. It enables the USB peripheral and
USB Reset interrupt, and transitions the part to the pow-
ered state to prepare the device for enumeration. See
enumeration process.
DeInitUSB disables the USB peripheral, removing the
device from the bus. An application might call
DeInitUSB if it was finished communicating to the host
and didn't want to be polled any more.
PutUSB (Buffer pointer, Buffer size, Endpoint) sends
data up to the host. The pointer to the block of data to
transmit is in the FSR/IRP, and the block size and end-
point is passed in W register. If the IN buffer is available
for that endpoint, PutUSB copies the buffer, flips the
Data 0/1 bit and sets the OWNS bit. A buffer not avail-
able would occur when it has been previously loaded
and the host has not requested that the USB peripheral
transmit it. In this case, a failure code would be returned
so the application can try again later.
GetUSB (Buffer Pointer, Endpoint) returns data sent
from the host. If the out buffer pointed to by the endpoint
number is ready, as indicated by the OWNS bit, the
buffer is copied from dual port RAM to the locations
pointed to by the buffer pointer, and resets the endpoint
for the next out transaction from the host. If no data is
available, it returns a failure code. Thus the functions of
polling for buffer ready and copying the data are com-
bined into the one function.
ServiceUSBInt handles all interrupts generated by the
USB peripheral. First, it copies the active buffer to com-
mon RAM, which provides a quick turn around on the
buffer in dual port RAM and also avoids having to
switch banks during processing of the buffer. File
USB_MAIN.ASM
gives
an
example
of
how
ServiceUSBInt would be invoked.
StallUSBEP/UnstallUSBEP sets or clears the stall bit
in the endpoint control register. The stall bit indicates to
the host that user intervention is required and until such
intervention is made, further attempts to communicate
with the endpoint will not be successful. Once the user
intervention has been made, UnstallUSBEP clears the
bit allowing communication to take place. These calls
are useful to signal to the host that user intervention is
required. An example of this might be a printer out of
paper.
SoftDetachUSB clears the DEV_ATT bit, electrically
disconnecting the device from the bus, then reconnect-
ing, so it can be re-enumerated by the host. This pro-
cess takes approximately 50 mS, to ensure that the host
has seen the device disconnect and reattach to the bus.
CheckSleep tests the UCTRL.UIDLE bit if set, indicat-
ing that there has been no activity on the bus for 3 mS.
If set, the device can be put to SLEEP, which puts the
part into a low power standby mode, until wakened by
bus activity. This has to be handled outside the ISR
because we need the interrupt to wake us from SLEEP,
and also because the application may not be ready to
SLEEP when the interrupt occurs. Instead, the applica-
tion should periodically call this function to poll the bit,
when the device is in a good place to SLEEP.
Prior to putting the device to SLEEP, it enables the
activity interrupt so the device will be awakened by the
first transition on the bus. The PICmicro device will
immediately jump to the ISR, recognize the activity
interrupt, which then disables the interrupt and resumes
processing
with
the
instruction
following
the
CheckSleep call.
745cov.book Page 73 Wednesday, August 2, 2000 8:24 AM