Initial commit of OpenSPARC T2 architecture model.
[OpenSPARC-T2-SAM] / obp / obp / dev / usb2 / hcd / ohci / bulk.fth
\ ========== Copyright Header Begin ==========================================
\
\ Hypervisor Software File: bulk.fth
\
\ Copyright (c) 2006 Sun Microsystems, Inc. All Rights Reserved.
\
\ - Do no alter or remove copyright notices
\
\ - Redistribution and use of this software in source and binary forms, with
\ or without modification, are permitted provided that the following
\ conditions are met:
\
\ - Redistribution of source code must retain the above copyright notice,
\ this list of conditions and the following disclaimer.
\
\ - Redistribution in binary form must reproduce the above copyright notice,
\ this list of conditions and the following disclaimer in the
\ documentation and/or other materials provided with the distribution.
\
\ Neither the name of Sun Microsystems, Inc. or the names of contributors
\ may be used to endorse or promote products derived from this software
\ without specific prior written permission.
\
\ This software is provided "AS IS," without a warranty of any kind.
\ ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES,
\ INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A
\ PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN
\ MICROSYSTEMS, INC. ("SUN") AND ITS LICENSORS SHALL NOT BE LIABLE FOR
\ ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR
\ DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN
\ OR ITS LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR
\ FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE
\ DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY,
\ ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN IF
\ SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
\
\ You acknowledge that this software is not designed, licensed or
\ intended for use in the design, construction, operation or maintenance of
\ any nuclear facility.
\
\ ========== Copyright Header End ============================================
id: @(#)bulk.fth 1.1 07/01/24
purpose: OHCI USB Controller bulk pipes transaction processing
\ See license at end of file
hex
headers
d# 500 instance value bulk-in-timeout
d# 500 constant bulk-out-timeout
0 instance value bulk-in-pipe
0 instance value bulk-out-pipe
0 instance value bulk-in-ed \ Instance variables for begin-bulk-in, bulk-in?,
0 instance value bulk-in-td \ restart-bulk-in and end-bulk-in.
: disable-bulk ( -- ) 20 hc-cntl-clr next-frame 0 28 ohci-reg! ;
: enable-bulk ( -- )
ed-bulk >ed-phys l@ 28 ohci-reg! \ Set HcBulkHeadED
4 hc-cmd! \ Mark TD added in bulk list
20 hc-cntl-set \ Enable bulk list processing
;
: insert-bulk ( ed -- )
ed-bulk if disable-bulk then
( ed ) insert-bulk-ed
enable-bulk
;
: remove-bulk ( ed -- )
disable-bulk
( ed ) remove-bulk-ed
ed-bulk if enable-bulk then
;
: bulk-in-data@ ( -- n ) bulk-in-pipe target di-in-data@ di-data>ed-data ;
: bulk-out-data@ ( -- n ) bulk-out-pipe target di-out-data@ di-data>ed-data ;
: bulk-in-data! ( n -- ) ed-data>di-data bulk-in-pipe target di-in-data! ;
: bulk-out-data! ( n -- ) ed-data>di-data bulk-out-pipe target di-out-data! ;
: fixup-bulk-in-data ( ed -- )
usb-error USB_ERR_STALL and if
drop bulk-in-pipe h# 80 or unstall-pipe
ED_TOGGLE_DATA0
else
>hced-tdhead le-l@
then
bulk-in-data!
;
: fixup-bulk-out-data ( ed -- )
usb-error USB_ERR_STALL and if
drop bulk-out-pipe unstall-pipe
ED_TOGGLE_DATA0
else
>hced-tdhead le-l@
then
bulk-out-data!
;
: process-bulk-args ( buf len pipe timeout -- )
to timeout
clear-usb-error
set-my-dev
( pipe ) set-my-char
2dup hcd-map-in to my-buf-phys to /my-buf to my-buf
;
: alloc-bulk-edtds ( -- ed td )
/my-buf if 2 else 1 then
( #tds ) alloc-edtds
;
: fill-bulk-io-tds ( td -- )
/my-buf ?dup 0= if drop exit then ( td len )
over >td-/cbp-all l! ( td )
TD_CC_NOTACCESSED TD_INTR_OFF or TD_ROUND_ON or TD_TOGGLE_USE_ED or
( td control )
fill-io-tds
;
: fill-bulk-ed ( dir ed -- )
over my-dev/pipe or my-speed or ED_SKIP_OFF or ED_FORMAT_G or
my-maxpayload d# 16 << or
over >hced-control le-l!
( ed ) dup >hced-tdhead le-l@ ( dir ed head )
rot ED_DIR_IN = if bulk-in-data@ else bulk-out-data@ then or
over >hced-tdhead le-l! ( ed )
( ed ) sync-edtds
;
: insert-my-bulk ( ed dir -- ) over fill-bulk-ed insert-bulk ;
: insert-my-bulk-in ( ed -- ) ED_DIR_IN insert-my-bulk ;
: insert-my-bulk-out ( ed -- ) ED_DIR_OUT insert-my-bulk ;
: remove-my-bulk ( ed -- ) dup remove-bulk free-edtds ;
external
: set-bulk-in-timeout ( t -- ) ?dup if to bulk-in-timeout then ;
: begin-bulk-in ( buf len pipe -- )
debug? if ." begin-bulk-in" cr then
bulk-in-ed if 3drop exit then \ Already started
dup to bulk-in-pipe
bulk-in-timeout process-bulk-args
alloc-bulk-edtds to bulk-in-td to bulk-in-ed
\ IN TD
bulk-in-td fill-bulk-io-tds
\ Start bulk in transaction
bulk-in-ed insert-my-bulk-in
;
: bulk-in? ( -- actual usberr )
bulk-in-ed 0= if 0 USB_ERR_INV_OP exit then
clear-usb-error ( )
process-hc-status ( )
bulk-in-ed dup sync-edtds ( ed )
ed-done? if ( )
bulk-in-td error? if
0 ( actual )
else
bulk-in-td dup get-actual ( td actual )
over >td-cbp l@ rot >td-pcbp l@ 2 pick dma-sync ( actual )
then
usb-error ( actual usberr )
bulk-in-ed fixup-bulk-in-data ( actual usberr )
else
0 usb-error ( actual usberr )
then
;
headers
: restart-bulk-in-td ( td -- )
begin ?dup while
dup >td-next l@ if
TD_CC_NOTACCESSED TD_DIR_IN or TD_INTR_OFF or TD_ROUND_ON or
over >hctd-control le-l!
dup >td-pcbp l@ over >hctd-cbp le-l!
dup >td-next l@ >td-phys l@ over >hctd-next le-l!
then
>td-next l@
repeat
;
external
: restart-bulk-in ( -- )
debug? if ." restart-bulk-in" cr then
bulk-in-ed 0= if exit then
bulk-in-ed ed-set-skip
\ Setup TD again
bulk-in-td restart-bulk-in-td
\ Setup ED again
bulk-in-td >td-phys l@ bulk-in-data@ or bulk-in-ed >hced-tdhead le-l!
bulk-in-ed dup sync-edtds
ed-unset-skip
enable-bulk
;
: end-bulk-in ( -- )
debug? if ." end-bulk-in" cr then
bulk-in-ed 0= if exit then
bulk-in-td map-out-cbp
bulk-in-ed remove-my-bulk
0 to bulk-in-ed 0 to bulk-in-td
;
: bulk-in ( buf len pipe -- actual usberr )
debug? if ." bulk-in" cr then
dup to bulk-in-pipe
bulk-in-timeout process-bulk-args ( )
alloc-bulk-edtds to my-td to my-ed ( )
\ IN TDs
my-td fill-bulk-io-tds ( )
\ Start bulk in transaction
my-ed insert-my-bulk-in ( )
\ Process results
my-ed done? if
0 ( actual ) \ System error, timeout
else
my-td error? if
0 ( actual ) \ USB error
else
my-td dup get-actual ( td actual )
over >td-cbp l@ rot >td-pcbp l@ 2 pick dma-sync ( actual )
then
then
usb-error ( actual usberr )
my-ed dup fixup-bulk-in-data ( actual usberr ed )
my-td map-out-cbp ( actual usberr ed )
remove-my-bulk ( actual usberr )
;
: bulk-out ( buf len pipe -- usberr )
debug? if ." bulk-out" cr then
dup to bulk-out-pipe
bulk-out-timeout process-bulk-args
alloc-bulk-edtds to my-td to my-ed
\ OUT TDs
my-td fill-bulk-io-tds
\ Start bulk out transaction
my-ed insert-my-bulk-out
\ Process results
my-ed done? 0= if my-td error? drop then
usb-error ( actual usberr )
my-ed dup fixup-bulk-out-data
my-td map-out-cbp
remove-my-bulk
;
headers
: (end-extra) ( -- ) end-bulk-in ;
\ LICENSE_BEGIN
\ Copyright (c) 2006 FirmWorks
\
\ Permission is hereby granted, free of charge, to any person obtaining
\ a copy of this software and associated documentation files (the
\ "Software"), to deal in the Software without restriction, including
\ without limitation the rights to use, copy, modify, merge, publish,
\ distribute, sublicense, and/or sell copies of the Software, and to
\ permit persons to whom the Software is furnished to do so, subject to
\ the following conditions:
\
\ The above copyright notice and this permission notice shall be
\ included in all copies or substantial portions of the Software.
\
\ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
\ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
\ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
\ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
\ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
\ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
\ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
\
\ LICENSE_END