1981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/*
2981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * BusDrv.h
3981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *
4981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * Copyright(c) 1998 - 2009 Texas Instruments. All rights reserved.
5981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * All rights reserved.
6981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *
7981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * Redistribution and use in source and binary forms, with or without
8981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * modification, are permitted provided that the following conditions
9981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * are met:
10981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *
11981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *  * Redistributions of source code must retain the above copyright
12981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *    notice, this list of conditions and the following disclaimer.
13981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *  * Redistributions in binary form must reproduce the above copyright
14981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *    notice, this list of conditions and the following disclaimer in
15981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *    the documentation and/or other materials provided with the
16981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *    distribution.
17981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *  * Neither the name Texas Instruments nor the names of its
18981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *    contributors may be used to endorse or promote products derived
19981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *    from this software without specific prior written permission.
20981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *
21981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt */
33981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
34981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
35981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/** \file   BusDrv.h
36981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *  \brief  Bus-Driver module API definition
37981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *
38981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt *  \see    SdioBusDrv.c, WspiBusDrv.c
39981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt */
40981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
41981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#ifndef __BUS_DRV_API_H__
42981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define __BUS_DRV_API_H__
43981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
44981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
45981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#include "TxnDefs.h"
46981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#include "queue.h"
47981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
48981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
49981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/************************************************************************
50981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * Defines
51981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt ************************************************************************/
52981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
53981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define WSPI_PAD_LEN_WRITE          4
54981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define WSPI_PAD_LEN_READ           8
55981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define MAX_XFER_BUFS               4
56981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
57981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_STATUS_OK         0
58981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_STATUS_ERROR      1
59981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_STATUS_RECOVERY   2
60981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
61981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_DIRECTION_WRITE         0
62981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_DIRECTION_READ          1
63981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
64981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_HIGH_PRIORITY           0
65981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_LOW_PRIORITY            1
66981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_NUM_PRIORITYS           2
67981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
68981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_INC_ADDR                0
69981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_FIXED_ADDR              1
70981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_NON_SLEEP_ELP           1
71981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_SLEEP_ELP               0
72981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
73653850f71f9caaa41af19cadbab24bb5e655daf4Dmitry Shmidt#define NUM_OF_PARTITION            4
74653850f71f9caaa41af19cadbab24bb5e655daf4Dmitry Shmidt
75981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/************************************************************************
76981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * Macros
77981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt ************************************************************************/
78981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/* Get field from TTxnStruct->uTxnParams */
79981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_GET_PRIORITY(pTxn)            ( (pTxn->uTxnParams & 0x00000003) >> 0 )
80981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_GET_FUNC_ID(pTxn)             ( (pTxn->uTxnParams & 0x0000000C) >> 2 )
81981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_GET_DIRECTION(pTxn)           ( (pTxn->uTxnParams & 0x00000010) >> 4 )
82981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_GET_FIXED_ADDR(pTxn)          ( (pTxn->uTxnParams & 0x00000020) >> 5 )
83981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_GET_MORE(pTxn)                ( (pTxn->uTxnParams & 0x00000040) >> 6 )
84981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_GET_SINGLE_STEP(pTxn)         ( (pTxn->uTxnParams & 0x00000080) >> 7 )
85981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_GET_STATUS(pTxn)              ( (pTxn->uTxnParams & 0x00000F00) >> 8 )
86981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
87981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/* Set field in TTxnStruct->uTxnParams */
88981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_SET_PRIORITY(pTxn, uValue)    ( pTxn->uTxnParams = (pTxn->uTxnParams & ~0x00000003) | (uValue << 0 ) )
89981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_SET_FUNC_ID(pTxn, uValue)     ( pTxn->uTxnParams = (pTxn->uTxnParams & ~0x0000000C) | (uValue << 2 ) )
90981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_SET_DIRECTION(pTxn, uValue)   ( pTxn->uTxnParams = (pTxn->uTxnParams & ~0x00000010) | (uValue << 4 ) )
91981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_SET_FIXED_ADDR(pTxn, uValue)  ( pTxn->uTxnParams = (pTxn->uTxnParams & ~0x00000020) | (uValue << 5 ) )
92981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_SET_MORE(pTxn, uValue)        ( pTxn->uTxnParams = (pTxn->uTxnParams & ~0x00000040) | (uValue << 6 ) )
93981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_SET_SINGLE_STEP(pTxn, uValue) ( pTxn->uTxnParams = (pTxn->uTxnParams & ~0x00000080) | (uValue << 7 ) )
94981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_SET_STATUS(pTxn, uValue)      ( pTxn->uTxnParams = (pTxn->uTxnParams & ~0x00000F00) | (uValue << 8 ) )
95981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
96981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define TXN_PARAM_SET(pTxn, uPriority, uId, uDirection, uAddr) \
97981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt        TXN_PARAM_SET_PRIORITY(pTxn, uPriority); \
98981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt        TXN_PARAM_SET_FUNC_ID(pTxn, uId); \
99981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt        TXN_PARAM_SET_DIRECTION(pTxn, uDirection); \
100981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt        TXN_PARAM_SET_FIXED_ADDR(pTxn, uAddr);
101981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
102981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#define BUILD_TTxnStruct(pTxn, uAddr, pBuf, uLen, fCB, hCB) \
103981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    pTxn->aBuf[0] = (TI_UINT8*)(pBuf); \
104981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    pTxn->aLen[0] = (TI_UINT16)(uLen); \
105981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    pTxn->aLen[1] = 0;                 \
106981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    pTxn->uHwAddr = uAddr;             \
107981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    pTxn->hCbHandle = (void*)hCB;      \
108981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    pTxn->fTxnDoneCb = (void*)fCB;
109981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
110981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
111981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/************************************************************************
112981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * Types
113981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt ************************************************************************/
114981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/* The TxnDone CB called by the bus driver upon Async Txn completion */
115981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidttypedef void (*TBusDrvTxnDoneCb)(TI_HANDLE hCbHandle, void *pTxn);
116981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
117981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/* The TxnDone CB called by the TxnQueue upon Async Txn completion */
118981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidttypedef void (*TTxnQueueDoneCb)(TI_HANDLE hCbHandle, void *pTxn);
119981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
120981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/* The TxnDone CB of the specific Txn originator (Xfer layer) called upon Async Txn completion */
121981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidttypedef void (*TTxnDoneCb)(TI_HANDLE hCbHandle, void *pTxn);
122981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
123981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/* The transactions structure */
124981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidttypedef struct
125981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt{
126981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TQueNodeHdr  tTxnQNode;                /* Header for queueing */
127981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TI_UINT32    uTxnParams;               /* Txn attributes (bit fields) - see macros above */
128981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TI_UINT32    uHwAddr;                  /* Physical (32 bits) HW Address */
129981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TTxnDoneCb   fTxnDoneCb;               /* CB called by TwIf upon Async Txn completion (may be NULL) */
130981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TI_HANDLE    hCbHandle;                /* The handle to use when calling fTxnDoneCb */
131981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TI_UINT16    aLen[MAX_XFER_BUFS];      /* Lengths of the following aBuf data buffers respectively.
132981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt                                              Zero length marks last used buffer, or MAX_XFER_BUFS of all are used. */
133981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TI_UINT8*    aBuf[MAX_XFER_BUFS];      /* Host data buffers to be written to or read from the device */
134981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TI_UINT8     aWspiPad[WSPI_PAD_LEN_READ]; /* Padding used by WSPI bus driver for its header or fixed-busy bytes */
135981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
136981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt} TTxnStruct;
137981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
138981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/* Parameters for all bus types configuration in ConnectBus process */
139981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
140981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidttypedef struct
141981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt{
142981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TI_UINT32    uBlkSizeShift;
143981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TI_UINT32    uBusDrvThreadPriority;
144981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt} TSdioCfg;
145981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
146981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidttypedef struct
147981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt{
148981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TI_UINT32    uDummy;
149981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt} TWspiCfg;
150981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
151981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidttypedef struct
152981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt{
153981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TI_UINT32    uBaudRate;
154981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt} TUartCfg;
155981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
156981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidttypedef union
157981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt{
158981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TSdioCfg    tSdioCfg;
159981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TWspiCfg    tWspiCfg;
160981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt    TUartCfg    tUartCfg;
161981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
162981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt} TBusDrvCfg;
163981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
164981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
165653850f71f9caaa41af19cadbab24bb5e655daf4Dmitry Shmidttypedef struct
166653850f71f9caaa41af19cadbab24bb5e655daf4Dmitry Shmidt{
167653850f71f9caaa41af19cadbab24bb5e655daf4Dmitry Shmidt    TI_UINT32   uMemAdrr;
168653850f71f9caaa41af19cadbab24bb5e655daf4Dmitry Shmidt    TI_UINT32   uMemSize;
169653850f71f9caaa41af19cadbab24bb5e655daf4Dmitry Shmidt} TPartition;
170653850f71f9caaa41af19cadbab24bb5e655daf4Dmitry Shmidt
171981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt/************************************************************************
172981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt * Functions
173981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt ************************************************************************/
174981801b95b81e6d1c7a2085967406e86af0f08fcDmitry ShmidtTI_HANDLE   busDrv_Create     (TI_HANDLE hOs);
175981801b95b81e6d1c7a2085967406e86af0f08fcDmitry ShmidtTI_STATUS   busDrv_Destroy    (TI_HANDLE hBusDrv);
176981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidtvoid        busDrv_Init       (TI_HANDLE hBusDrv, TI_HANDLE hReport);
177981801b95b81e6d1c7a2085967406e86af0f08fcDmitry ShmidtTI_STATUS   busDrv_ConnectBus (TI_HANDLE        hBusDrv,
178981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt                               TBusDrvCfg       *pBusDrvCfg,
179981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt                               TBusDrvTxnDoneCb fCbFunc,
180981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt                               TI_HANDLE        hCbArg,
181981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt                               TBusDrvTxnDoneCb fConnectCbFunc);
182981801b95b81e6d1c7a2085967406e86af0f08fcDmitry ShmidtTI_STATUS   busDrv_DisconnectBus (TI_HANDLE hBusDrv);
183981801b95b81e6d1c7a2085967406e86af0f08fcDmitry ShmidtETxnStatus  busDrv_Transact   (TI_HANDLE hBusDrv, TTxnStruct *pTxn);
184981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
185981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt#endif /*__BUS_DRV_API_H__*/
186981801b95b81e6d1c7a2085967406e86af0f08fcDmitry Shmidt
187