1 /**********************************************************************
4 * Contact: support@cavium.com
5 * Please include "LiquidIO" in the subject.
7 * Copyright (c) 2003-2016 Cavium, Inc.
9 * This file is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License, Version 2, as
11 * published by the Free Software Foundation.
13 * This file is distributed in the hope that it will be useful, but
14 * AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty
15 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, TITLE, or
16 * NONINFRINGEMENT. See the GNU General Public License for more
18 **********************************************************************/
20 /*! \file response_manager.h
21 * \brief Host Driver: Response queues for host instructions.
24 #ifndef __RESPONSE_MANAGER_H__
25 #define __RESPONSE_MANAGER_H__
27 /** Maximum ordered requests to process in every invocation of
28 * lio_process_ordered_list(). The function will continue to process requests
29 * as long as it can find one that has finished processing. If it keeps
30 * finding requests that have completed, the function can run for ever. The
31 * value defined here sets an upper limit on the number of requests it can
32 * process before it returns control to the poll thread.
34 #define MAX_ORD_REQS_TO_PROCESS 4096
36 /** Head of a response list. There are several response lists in the
37 * system. One for each response order- Unordered, ordered
38 * and 1 for noresponse entries on each instruction queue.
40 struct octeon_response_list
{
41 /** List structure to add delete pending entries to */
42 struct list_head head
;
44 /** A lock for this response list */
47 atomic_t pending_req_count
;
50 /** The type of response list.
53 OCTEON_ORDERED_LIST
= 0,
54 OCTEON_UNORDERED_NONBLOCKING_LIST
= 1,
55 OCTEON_UNORDERED_BLOCKING_LIST
= 2,
56 OCTEON_ORDERED_SC_LIST
= 3,
57 OCTEON_DONE_SC_LIST
= 4,
58 OCTEON_ZOMBIE_SC_LIST
= 5
61 /** Response Order values for a Octeon Request. */
63 OCTEON_RESP_ORDERED
= 0,
64 OCTEON_RESP_UNORDERED
= 1,
65 OCTEON_RESP_NORESPONSE
= 2
68 /** Error codes used in Octeon Host-Core communication.
71 * ---------------------------------
73 * ---------------------------------
74 * Error codes are 32-bit wide. The upper 16-bits, called Major Error Number,
75 * are reserved to identify the group to which the error code belongs. The
76 * lower 16-bits, called Minor Error Number, carry the actual code.
78 * So error codes are (MAJOR NUMBER << 16)| MINOR_NUMBER.
81 /*------------ Error codes used by host driver -----------------*/
82 #define DRIVER_MAJOR_ERROR_CODE 0x0000
83 /*------ Error codes used by firmware (bits 15..0 set by firmware */
84 #define FIRMWARE_MAJOR_ERROR_CODE 0x0001
86 /** A value of 0x00000000 indicates no error i.e. success */
87 #define DRIVER_ERROR_NONE 0x00000000
89 #define DRIVER_ERROR_REQ_PENDING 0x00000001
90 #define DRIVER_ERROR_REQ_TIMEOUT 0x00000003
91 #define DRIVER_ERROR_REQ_EINTR 0x00000004
92 #define DRIVER_ERROR_REQ_ENXIO 0x00000006
93 #define DRIVER_ERROR_REQ_ENOMEM 0x0000000C
94 #define DRIVER_ERROR_REQ_EINVAL 0x00000016
95 #define DRIVER_ERROR_REQ_FAILED 0x000000ff
97 /** Status for a request.
98 * If a request is not queued to Octeon by the driver, the driver returns
99 * an error condition that's describe by one of the OCTEON_REQ_ERR_* value
100 * below. If the request is successfully queued, the driver will return
101 * a OCTEON_REQUEST_PENDING status. OCTEON_REQUEST_TIMEOUT and
102 * OCTEON_REQUEST_INTERRUPTED are only returned by the driver if the
103 * response for request failed to arrive before a time-out period or if
104 * the request processing * got interrupted due to a signal respectively.
107 OCTEON_REQUEST_DONE
= (DRIVER_ERROR_NONE
),
108 OCTEON_REQUEST_PENDING
= (DRIVER_ERROR_REQ_PENDING
),
109 OCTEON_REQUEST_TIMEOUT
= (DRIVER_ERROR_REQ_TIMEOUT
),
110 OCTEON_REQUEST_INTERRUPTED
= (DRIVER_ERROR_REQ_EINTR
),
111 OCTEON_REQUEST_NO_DEVICE
= (0x00000021),
112 OCTEON_REQUEST_NOT_RUNNING
,
113 OCTEON_REQUEST_INVALID_IQ
,
114 OCTEON_REQUEST_INVALID_BUFCNT
,
115 OCTEON_REQUEST_INVALID_RESP_ORDER
,
116 OCTEON_REQUEST_NO_MEMORY
,
117 OCTEON_REQUEST_INVALID_BUFSIZE
,
118 OCTEON_REQUEST_NO_PENDING_ENTRY
,
119 OCTEON_REQUEST_NO_IQ_SPACE
= (0x7FFFFFFF)
123 #define FIRMWARE_STATUS_CODE(status) \
124 ((FIRMWARE_MAJOR_ERROR_CODE << 16) | (status))
126 /** Initialize the response lists. The number of response lists to create is
128 * @param octeon_dev - the octeon device structure.
130 int octeon_setup_response_list(struct octeon_device
*octeon_dev
);
132 void octeon_delete_response_list(struct octeon_device
*octeon_dev
);
134 /** Check the status of first entry in the ordered list. If the instruction at
135 * that entry finished processing or has timed-out, the entry is cleaned.
136 * @param octeon_dev - the octeon device structure.
137 * @param force_quit - the request is forced to timeout if this is 1
138 * @return 1 if the ordered list is empty, 0 otherwise.
140 int lio_process_ordered_list(struct octeon_device
*octeon_dev
,