Changeset 6428115 in mainline for uspace/srv/inet/icmp.c


Ignore:
Timestamp:
2012-03-11T23:07:29Z (12 years ago)
Author:
Jiri Svoboda <jiri@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
3b3c689
Parents:
ffa8912
Message:

Ping utility, ICMP echo send and receive.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/srv/inet/icmp.c

    rffa8912 r6428115  
    4444#include "icmp_std.h"
    4545#include "inet.h"
     46#include "inetping.h"
    4647#include "pdu.h"
    4748
     
    4950#define INET_TTL_MAX 255
    5051
    51 static int icmp_echo_request(inet_dgram_t *);
     52static int icmp_recv_echo_request(inet_dgram_t *);
     53static int icmp_recv_echo_reply(inet_dgram_t *);
    5254
    5355int icmp_recv(inet_dgram_t *dgram)
     
    6466        switch (type) {
    6567        case ICMP_ECHO_REQUEST:
    66                 return icmp_echo_request(dgram);
     68                return icmp_recv_echo_request(dgram);
     69        case ICMP_ECHO_REPLY:
     70                return icmp_recv_echo_reply(dgram);
    6771        default:
    6872                break;
     
    7276}
    7377
    74 static int icmp_echo_request(inet_dgram_t *dgram)
     78static int icmp_recv_echo_request(inet_dgram_t *dgram)
    7579{
    7680        icmp_echo_t *request, *reply;
     
    8084        int rc;
    8185
    82         log_msg(LVL_DEBUG, "icmp_echo_request()");
     86        log_msg(LVL_DEBUG, "icmp_recv_echo_request()");
    8387
    8488        if (dgram->size < sizeof(icmp_echo_t))
     
    103107        rdgram.src = dgram->dest;
    104108        rdgram.dest = dgram->src;
    105         rdgram.tos = 0;
     109        rdgram.tos = ICMP_TOS;
    106110        rdgram.data = reply;
    107111        rdgram.size = size;
     
    114118}
    115119
     120static int icmp_recv_echo_reply(inet_dgram_t *dgram)
     121{
     122        icmp_echo_t *reply;
     123        inetping_sdu_t sdu;
     124        uint16_t ident;
     125
     126        log_msg(LVL_DEBUG, "icmp_recv_echo_reply()");
     127
     128        if (dgram->size < sizeof(icmp_echo_t))
     129                return EINVAL;
     130
     131        reply = (icmp_echo_t *)dgram->data;
     132
     133        sdu.src = dgram->src;
     134        sdu.dest = dgram->dest;
     135        sdu.seq_no = uint16_t_be2host(reply->seq_no);
     136        sdu.data = reply + sizeof(icmp_echo_t);
     137        sdu.size = dgram->size - sizeof(icmp_echo_t);
     138        ident = uint16_t_be2host(reply->ident);
     139
     140        return inetping_recv(ident, &sdu);
     141}
     142
     143int icmp_ping_send(uint16_t ident, inetping_sdu_t *sdu)
     144{
     145        inet_dgram_t dgram;
     146        icmp_echo_t *request;
     147        void *rdata;
     148        size_t rsize;
     149        uint16_t checksum;
     150        int rc;
     151
     152        rsize = sizeof(icmp_echo_t) + sdu->size;
     153        rdata = calloc(rsize, 1);
     154        if (rdata == NULL)
     155                return ENOMEM;
     156
     157        request = (icmp_echo_t *)rdata;
     158
     159        request->type = ICMP_ECHO_REQUEST;
     160        request->code = 0;
     161        request->checksum = 0;
     162        request->ident = host2uint16_t_be(ident);
     163        request->seq_no = host2uint16_t_be(sdu->seq_no);
     164
     165        memcpy(rdata + sizeof(icmp_echo_t), sdu->data, sdu->size);
     166
     167        checksum = inet_checksum_calc(INET_CHECKSUM_INIT, rdata, rsize);
     168        request->checksum = host2uint16_t_be(checksum);
     169
     170        dgram.src = sdu->src;
     171        dgram.dest = sdu->dest;
     172        dgram.tos = ICMP_TOS;
     173        dgram.data = rdata;
     174        dgram.size = rsize;
     175
     176        rc = inet_route_packet(&dgram, IP_PROTO_ICMP, INET_TTL_MAX, 0);
     177
     178        free(rdata);
     179        return rc;
     180}
     181
    116182/** @}
    117183 */
Note: See TracChangeset for help on using the changeset viewer.