Commit 656b7afd authored by Stefan Richter's avatar Stefan Richter

firewire: core: fix fw_send_request kerneldoc comment

The present inline documentation of the fw_send_request() in-kernel API
refers to userland code that is not applicable to kernel drivers at all.
Reported-by: default avatarBen Gamari <bgamari.foss@gmail.com>

While we are at fixing the whole documentation of fw_send_request(),
also improve the rest of firewire-core's kerneldoc comments:
  - Add a bit of text concerning fw_run_transaction()'s call parameters.
  - Append () to function names and tab-align parameter descriptions as
    suggested by the example in Documentation/kernel-doc-nano-HOWTO.txt.
  - Remove kerneldoc markers from comments on static functions.
  - Remove outdated parameter descriptions at build_tree().
Signed-off-by: default avatarStefan Richter <stefanr@s5r6.in-berlin.de>
parent a8e93f3d
...@@ -107,11 +107,11 @@ static int textual_leaf_to_string(const u32 *block, char *buf, size_t size) ...@@ -107,11 +107,11 @@ static int textual_leaf_to_string(const u32 *block, char *buf, size_t size)
} }
/** /**
* fw_csr_string - reads a string from the configuration ROM * fw_csr_string() - reads a string from the configuration ROM
* @directory: e.g. root directory or unit directory * @directory: e.g. root directory or unit directory
* @key: the key of the preceding directory entry * @key: the key of the preceding directory entry
* @buf: where to put the string * @buf: where to put the string
* @size: size of @buf, in bytes * @size: size of @buf, in bytes
* *
* The string is taken from a minimal ASCII text descriptor leaf after * The string is taken from a minimal ASCII text descriptor leaf after
* the immediate entry with @key. The string is zero-terminated. * the immediate entry with @key. The string is zero-terminated.
......
...@@ -272,7 +272,7 @@ static void deallocate_channel(struct fw_card *card, int irm_id, ...@@ -272,7 +272,7 @@ static void deallocate_channel(struct fw_card *card, int irm_id,
} }
/** /**
* fw_iso_resource_manage - Allocate or deallocate a channel and/or bandwidth * fw_iso_resource_manage() - Allocate or deallocate a channel and/or bandwidth
* *
* In parameters: card, generation, channels_mask, bandwidth, allocate * In parameters: card, generation, channels_mask, bandwidth, allocate
* Out parameters: channel, bandwidth * Out parameters: channel, bandwidth
......
...@@ -174,12 +174,7 @@ static inline struct fw_node *fw_node(struct list_head *l) ...@@ -174,12 +174,7 @@ static inline struct fw_node *fw_node(struct list_head *l)
return list_entry(l, struct fw_node, link); return list_entry(l, struct fw_node, link);
} }
/** /*
* build_tree - Build the tree representation of the topology
* @self_ids: array of self IDs to create the tree from
* @self_id_count: the length of the self_ids array
* @local_id: the node ID of the local node
*
* This function builds the tree representation of the topology given * This function builds the tree representation of the topology given
* by the self IDs from the latest bus reset. During the construction * by the self IDs from the latest bus reset. During the construction
* of the tree, the function checks that the self IDs are valid and * of the tree, the function checks that the self IDs are valid and
...@@ -420,11 +415,10 @@ static void move_tree(struct fw_node *node0, struct fw_node *node1, int port) ...@@ -420,11 +415,10 @@ static void move_tree(struct fw_node *node0, struct fw_node *node1, int port)
} }
} }
/** /*
* update_tree - compare the old topology tree for card with the new * Compare the old topology tree for card with the new one specified by root.
* one specified by root. Queue the nodes and mark them as either * Queue the nodes and mark them as either found, lost or updated.
* found, lost or updated. Update the nodes in the card topology tree * Update the nodes in the card topology tree as we go.
* as we go.
*/ */
static void update_tree(struct fw_card *card, struct fw_node *root) static void update_tree(struct fw_card *card, struct fw_node *root)
{ {
......
...@@ -273,43 +273,49 @@ static int allocate_tlabel(struct fw_card *card) ...@@ -273,43 +273,49 @@ static int allocate_tlabel(struct fw_card *card)
} }
/** /**
* This function provides low-level access to the IEEE1394 transaction * fw_send_request() - submit a request packet for transmission
* logic. Most C programs would use either fw_read(), fw_write() or * @card: interface to send the request at
* fw_lock() instead - those function are convenience wrappers for * @t: transaction instance to which the request belongs
* this function. The fw_send_request() function is primarily * @tcode: transaction code
* provided as a flexible, one-stop entry point for languages bindings * @destination_id: destination node ID, consisting of bus_ID and phy_ID
* and protocol bindings. * @generation: bus generation in which request and response are valid
* @speed: transmission speed
* @offset: 48bit wide offset into destination's address space
* @payload: data payload for the request subaction
* @length: length of the payload, in bytes
* @callback: function to be called when the transaction is completed
* @callback_data: data to be passed to the transaction completion callback
* *
* FIXME: Document this function further, in particular the possible * Submit a request packet into the asynchronous request transmission queue.
* values for rcode in the callback. In short, we map ACK_COMPLETE to * Can be called from atomic context. If you prefer a blocking API, use
* RCODE_COMPLETE, internal errors set errno and set rcode to * fw_run_transaction() in a context that can sleep.
* RCODE_SEND_ERROR (which is out of range for standard ieee1394
* rcodes). All other rcodes are forwarded unchanged. For all
* errors, payload is NULL, length is 0.
* *
* Can not expect the callback to be called before the function * In case of lock requests, specify one of the firewire-core specific %TCODE_
* returns, though this does happen in some cases (ACK_COMPLETE and * constants instead of %TCODE_LOCK_REQUEST in @tcode.
* errors).
* *
* The payload is only used for write requests and must not be freed * Make sure that the value in @destination_id is not older than the one in
* until the callback has been called. * @generation. Otherwise the request is in danger to be sent to a wrong node.
* *
* @param card the card from which to send the request * In case of asynchronous stream packets i.e. %TCODE_STREAM_DATA, the caller
* @param tcode the tcode for this transaction. Do not use
* TCODE_LOCK_REQUEST directly, instead use TCODE_LOCK_MASK_SWAP
* etc. to specify tcode and ext_tcode.
* @param node_id the destination node ID (bus ID and PHY ID concatenated)
* @param generation the generation for which node_id is valid
* @param speed the speed to use for sending the request
* @param offset the 48 bit offset on the destination node
* @param payload the data payload for the request subaction
* @param length the length in bytes of the data to read
* @param callback function to be called when the transaction is completed
* @param callback_data pointer to arbitrary data, which will be
* passed to the callback
*
* In case of asynchronous stream packets i.e. TCODE_STREAM_DATA, the caller
* needs to synthesize @destination_id with fw_stream_packet_destination_id(). * needs to synthesize @destination_id with fw_stream_packet_destination_id().
* It will contain tag, channel, and sy data instead of a node ID then.
*
* The payload buffer at @data is going to be DMA-mapped except in case of
* quadlet-sized payload or of local (loopback) requests. Hence make sure that
* the buffer complies with the restrictions for DMA-mapped memory. The
* @payload must not be freed before the @callback is called.
*
* In case of request types without payload, @data is NULL and @length is 0.
*
* After the transaction is completed successfully or unsuccessfully, the
* @callback will be called. Among its parameters is the response code which
* is either one of the rcodes per IEEE 1394 or, in case of internal errors,
* the firewire-core specific %RCODE_SEND_ERROR.
*
* Note some timing corner cases: fw_send_request() may complete much earlier
* than when the request packet actually hits the wire. On the other hand,
* transaction completion and hence execution of @callback may happen even
* before fw_send_request() returns.
*/ */
void fw_send_request(struct fw_card *card, struct fw_transaction *t, int tcode, void fw_send_request(struct fw_card *card, struct fw_transaction *t, int tcode,
int destination_id, int generation, int speed, int destination_id, int generation, int speed,
...@@ -375,9 +381,11 @@ static void transaction_callback(struct fw_card *card, int rcode, ...@@ -375,9 +381,11 @@ static void transaction_callback(struct fw_card *card, int rcode,
} }
/** /**
* fw_run_transaction - send request and sleep until transaction is completed * fw_run_transaction() - send request and sleep until transaction is completed
* *
* Returns the RCODE. * Returns the RCODE. See fw_send_request() for parameter documentation.
* Unlike fw_send_request(), @data points to the payload of the request or/and
* to the payload of the response.
*/ */
int fw_run_transaction(struct fw_card *card, int tcode, int destination_id, int fw_run_transaction(struct fw_card *card, int tcode, int destination_id,
int generation, int speed, unsigned long long offset, int generation, int speed, unsigned long long offset,
...@@ -495,9 +503,9 @@ static bool is_in_fcp_region(u64 offset, size_t length) ...@@ -495,9 +503,9 @@ static bool is_in_fcp_region(u64 offset, size_t length)
} }
/** /**
* fw_core_add_address_handler - register for incoming requests * fw_core_add_address_handler() - register for incoming requests
* @handler: callback * @handler: callback
* @region: region in the IEEE 1212 node space address range * @region: region in the IEEE 1212 node space address range
* *
* region->start, ->end, and handler->length have to be quadlet-aligned. * region->start, ->end, and handler->length have to be quadlet-aligned.
* *
...@@ -552,7 +560,7 @@ int fw_core_add_address_handler(struct fw_address_handler *handler, ...@@ -552,7 +560,7 @@ int fw_core_add_address_handler(struct fw_address_handler *handler,
EXPORT_SYMBOL(fw_core_add_address_handler); EXPORT_SYMBOL(fw_core_add_address_handler);
/** /**
* fw_core_remove_address_handler - unregister an address handler * fw_core_remove_address_handler() - unregister an address handler
*/ */
void fw_core_remove_address_handler(struct fw_address_handler *handler) void fw_core_remove_address_handler(struct fw_address_handler *handler)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment