Ignore:
Timestamp:
2011-08-03T17:34:57Z (13 years ago)
Author:
Oleg Romanenko <romanenko.oleg@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
1940326
Parents:
52a79081 (diff), 3fab770 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merge from mainline

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/lib/net/generic/packet_remote.c

    r52a79081 ra33f0a6  
    5151 * Create the local packet mapping as well.
    5252 *
    53  * @param[in]  phone     The packet server module phone.
    54  * @param[out] packet    The packet reference pointer to store the received
     53 * @param[in]  sess      Packet server module session.
     54 * @param[out] packet    Packet reference pointer to store the received
    5555 *                       packet reference.
    56  * @param[in]  packet_id The packet identifier.
    57  * @param[in]  size      The packet total size in bytes.
     56 * @param[in]  packet_id Packet identifier.
     57 * @param[in]  size      Packet total size in bytes.
    5858 *
    5959 * @return EOK on success.
    6060 * @return Other error codes as defined for the pm_add() function.
    61  * @return Other error codes as defined for the async_share_in_start() function.
    62  *
    63  */
    64 static int
    65 packet_return(int phone, packet_t **packet, packet_id_t packet_id, size_t size)
    66 {
     61 * @return Other error codes as defined for the async_share_in_start()
     62 *         function.
     63 *
     64 */
     65static int packet_return(async_sess_t *sess, packet_t **packet,
     66    packet_id_t packet_id, size_t size)
     67{
     68        *packet = (packet_t *) as_get_mappable_page(size);
     69       
     70        async_exch_t *exch = async_exchange_begin(sess);
    6771        ipc_call_t answer;
    68         aid_t message;
    69         int rc;
    70        
    71         message = async_send_1(phone, NET_PACKET_GET, packet_id, &answer);
    72 
    73         *packet = (packet_t *) as_get_mappable_page(size);
    74         rc = async_share_in_start_0_0(phone, *packet, size);
     72        aid_t message = async_send_1(exch, NET_PACKET_GET, packet_id, &answer);
     73        int rc = async_share_in_start_0_0(exch, *packet, size);
     74        async_exchange_end(exch);
     75       
     76        sysarg_t result;
     77        async_wait_for(message, &result);
     78       
    7579        if (rc != EOK) {
    7680                munmap(*packet, size);
    77                 async_wait_for(message, NULL);
    7881                return rc;
    7982        }
     83       
    8084        rc = pm_add(*packet);
    8185        if (rc != EOK) {
    8286                munmap(*packet, size);
    83                 async_wait_for(message, NULL);
    8487                return rc;
    8588        }
    8689       
    87         sysarg_t result;
    88         async_wait_for(message, &result);
    89        
    9090        return result;
    9191}
    9292
    93 /** Translates the packet identifier to the packet reference.
    94  *
    95  * Tries to find mapping first.
    96  * Contacts the packet server to share the packet if the mapping is not present.
    97  *
    98  * @param[in] phone     The packet server module phone.
    99  * @param[out] packet   The packet reference.
    100  * @param[in] packet_id The packet identifier.
    101  * @return              EOK on success.
    102  * @return              EINVAL if the packet parameter is NULL.
    103  * @return              Other error codes as defined for the NET_PACKET_GET_SIZE
    104  *                      message.
    105  * @return              Other error codes as defined for the packet_return()
    106  *                      function.
    107  */
    108 int packet_translate_remote(int phone, packet_t **packet, packet_id_t packet_id)
    109 {
    110         int rc;
    111        
     93/** Translate the packet identifier to the packet reference.
     94 *
     95 * Try to find mapping first. The packet server is asked to share
     96 * the packet if the mapping is not present.
     97 *
     98 * @param[in]  sess      Packet server module session.
     99 * @param[out] packet    Packet reference.
     100 * @param[in]  packet_id Packet identifier.
     101 *
     102 * @return EOK on success.
     103 * @return EINVAL if the packet parameter is NULL.
     104 * @return Other error codes as defined for the NET_PACKET_GET_SIZE
     105 *         message.
     106 * @return Other error codes as defined for the packet_return()
     107 *         function.
     108 *
     109 */
     110int packet_translate_remote(async_sess_t *sess, packet_t **packet,
     111    packet_id_t packet_id)
     112{
    112113        if (!packet)
    113114                return EINVAL;
     
    115116        *packet = pm_find(packet_id);
    116117        if (!*packet) {
     118                async_exch_t *exch = async_exchange_begin(sess);
    117119                sysarg_t size;
     120                int rc = async_req_1_1(exch, NET_PACKET_GET_SIZE, packet_id,
     121                    &size);
     122                async_exchange_end(exch);
    118123               
    119                 rc = async_req_1_1(phone, NET_PACKET_GET_SIZE, packet_id,
    120                     &size);
    121124                if (rc != EOK)
    122125                        return rc;
    123                 rc = packet_return(phone, packet, packet_id, size);
     126               
     127                rc = packet_return(sess, packet, packet_id, size);
    124128                if (rc != EOK)
    125129                        return rc;
    126130        }
     131       
    127132        if ((*packet)->next) {
    128133                packet_t *next;
    129                
    130                 return packet_translate_remote(phone, &next, (*packet)->next);
     134                return packet_translate_remote(sess, &next, (*packet)->next);
    131135        }
    132136       
     
    134138}
    135139
    136 /** Obtains the packet of the given dimensions.
    137  *
    138  * Contacts the packet server to return the appropriate packet.
    139  *
    140  * @param[in] phone     The packet server module phone.
    141  * @param[in] addr_len  The source and destination addresses maximal length in
    142  *                      bytes.
    143  * @param[in] max_prefix The maximal prefix length in bytes.
    144  * @param[in] max_content The maximal content length in bytes.
    145  * @param[in] max_suffix The maximal suffix length in bytes.
    146  * @return              The packet reference.
    147  * @return              NULL on error.
    148  */
    149 packet_t *packet_get_4_remote(int phone, size_t max_content, size_t addr_len,
    150     size_t max_prefix, size_t max_suffix)
    151 {
     140/** Obtain the packet of given dimensions.
     141 *
     142 * Contact the packet server to return the appropriate packet.
     143 *
     144 * @param[in] sess        Packet server module session.
     145 * @param[in] addr_len    Source and destination addresses maximal length
     146 *                        in bytes.
     147 * @param[in] max_prefix  Maximal prefix length in bytes.
     148 * @param[in] max_content Maximal content length in bytes.
     149 * @param[in] max_suffix  Maximal suffix length in bytes.
     150 *
     151 * @return The packet reference.
     152 * @return NULL on error.
     153 *
     154 */
     155packet_t *packet_get_4_remote(async_sess_t *sess, size_t max_content,
     156    size_t addr_len, size_t max_prefix, size_t max_suffix)
     157{
     158        async_exch_t *exch = async_exchange_begin(sess);
    152159        sysarg_t packet_id;
    153160        sysarg_t size;
    154         int rc;
    155        
    156         rc = async_req_4_2(phone, NET_PACKET_CREATE_4, max_content, addr_len,
     161        int rc = async_req_4_2(exch, NET_PACKET_CREATE_4, max_content, addr_len,
    157162            max_prefix, max_suffix, &packet_id, &size);
     163        async_exchange_end(exch);
     164       
    158165        if (rc != EOK)
    159166                return NULL;
    160167       
    161        
    162168        packet_t *packet = pm_find(packet_id);
    163169        if (!packet) {
    164                 rc = packet_return(phone, &packet, packet_id, size);
     170                rc = packet_return(sess, &packet, packet_id, size);
    165171                if (rc != EOK)
    166172                        return NULL;
     
    170176}
    171177
    172 /** Obtains the packet of the given content size.
    173  *
    174  * Contacts the packet server to return the appropriate packet.
    175  *
    176  * @param[in] phone     The packet server module phone.
    177  * @param[in] content   The maximal content length in bytes.
    178  * @return              The packet reference.
    179  * @return              NULL on error.
    180  */
    181 packet_t *packet_get_1_remote(int phone, size_t content)
    182 {
     178/** Obtain the packet of given content size.
     179 *
     180 * Contact the packet server to return the appropriate packet.
     181 *
     182 * @param[in] sess    Packet server module session.
     183 * @param[in] content Maximal content length in bytes.
     184 *
     185 * @return The packet reference.
     186 * @return NULL on error.
     187 *
     188 */
     189packet_t *packet_get_1_remote(async_sess_t *sess, size_t content)
     190{
     191        async_exch_t *exch = async_exchange_begin(sess);
    183192        sysarg_t packet_id;
    184193        sysarg_t size;
    185         int rc;
    186        
    187         rc = async_req_1_2(phone, NET_PACKET_CREATE_1, content, &packet_id,
     194        int rc = async_req_1_2(exch, NET_PACKET_CREATE_1, content, &packet_id,
    188195            &size);
     196        async_exchange_end(exch);
     197       
    189198        if (rc != EOK)
    190199                return NULL;
     
    192201        packet_t *packet = pm_find(packet_id);
    193202        if (!packet) {
    194                 rc = packet_return(phone, &packet, packet_id, size);
     203                rc = packet_return(sess, &packet, packet_id, size);
    195204                if (rc != EOK)
    196205                        return NULL;
     
    200209}
    201210
    202 /** Releases the packet queue.
     211/** Release the packet queue.
    203212 *
    204213 * All packets in the queue are marked as free for use.
     
    207216 * received or obtained again.
    208217 *
    209  * @param[in] phone     The packet server module phone.
    210  * @param[in] packet_id The packet identifier.
    211  */
    212 void pq_release_remote(int phone, packet_id_t packet_id)
    213 {
    214         async_msg_1(phone, NET_PACKET_RELEASE, packet_id);
     218 * @param[in] sess      Packet server module session.
     219 * @param[in] packet_id Packet identifier.
     220 *
     221 */
     222void pq_release_remote(async_sess_t *sess, packet_id_t packet_id)
     223{
     224        async_exch_t *exch = async_exchange_begin(sess);
     225        async_msg_1(exch, NET_PACKET_RELEASE, packet_id);
     226        async_exchange_end(exch);
    215227}
    216228
Note: See TracChangeset for help on using the changeset viewer.