⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 libnet_build_ospf.c

📁 tcp数据流重放工具
💻 C
📖 第 1 页 / 共 2 页
字号:
			     "%s(): payload inconsistency\n", __func__);        goto bad;    }     if (payload && payload_s)    {        n = libnet_pblock_append(l, p, payload, payload_s);        if (n == -1)        {            goto bad;        }    }    return (ptag ? ptag : libnet_pblock_update(l, p, h,             LIBNET_PBLOCK_OSPF_LSU_H));bad:    libnet_pblock_delete(l, p);    return (-1);}libnet_ptag_tlibnet_build_ospfv2_lsa(u_int16_t age, u_int8_t opts, u_int8_t type, u_int lsid,             u_int32_t advrtr, u_int seqnum, u_int16_t sum, u_int16_t len,             u_int8_t *payload, u_int32_t payload_s, libnet_t *l, libnet_ptag_t ptag){    u_int32_t n, h;    libnet_pblock_t *p;    struct libnet_lsa_hdr lsa_hdr;    if (l == NULL)    {         return (-1);    }     n = LIBNET_OSPF_LSA_H + payload_s;    h = len + payload_s;    /*     *  Find the existing protocol block if a ptag is specified, or create     *  a new one.     */    p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_OSPF_LSA_H);    if (p == NULL)    {        return (-1);    }	memset(&lsa_hdr, 0, sizeof(lsa_hdr));	lsa_hdr.lsa_age         = htons(age);    lsa_hdr.lsa_opts        = opts;    lsa_hdr.lsa_type        = type;    lsa_hdr.lsa_id          = htonl(lsid);    lsa_hdr.lsa_adv.s_addr  = htonl(advrtr);    lsa_hdr.lsa_seq         = htonl(seqnum);    lsa_hdr.lsa_cksum       = sum;    lsa_hdr.lsa_len         = htons(h);    n = libnet_pblock_append(l, p, (u_int8_t *)&lsa_hdr, LIBNET_OSPF_LSA_H);    if (n == -1)    {        goto bad;    }    if ((payload && !payload_s) || (!payload && payload_s))    {         snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,			     "%s(): payload inconsistency\n", __func__);        goto bad;    }     if (payload && payload_s)    {        n = libnet_pblock_append(l, p, payload, payload_s);        if (n == -1)        {            goto bad;        }    }    if (sum == 0)    {        /*         *  If checksum is zero, by default libnet will compute a checksum         *  for the user.  The programmer can override this by calling         *  libnet_toggle_checksum(l, ptag, 1);         */        libnet_pblock_setflags(p, LIBNET_PBLOCK_DO_CHECKSUM);    }    return (ptag ? ptag : libnet_pblock_update(l, p, h,             LIBNET_PBLOCK_OSPF_LSA_H));bad:    libnet_pblock_delete(l, p);    return (-1);}libnet_ptag_tlibnet_build_ospfv2_lsa_rtr(u_int16_t flags, u_int16_t num, u_int id, u_int data,             u_int8_t type, u_int8_t tos, u_int16_t metric, u_int8_t *payload,            u_int32_t payload_s, libnet_t *l, libnet_ptag_t ptag){    u_int32_t n, h;    libnet_pblock_t *p;    struct libnet_rtr_lsa_hdr rtr_lsa_hdr;    if (l == NULL)    {         return (-1);    }     n = LIBNET_OSPF_LS_RTR_H + payload_s;    h = 0;    /*     *  Find the existing protocol block if a ptag is specified, or create     *  a new one.     */    p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_LS_RTR_H);    if (p == NULL)    {        return (-1);    }	memset(&rtr_lsa_hdr, 0, sizeof(rtr_lsa_hdr));	rtr_lsa_hdr.rtr_flags       = htons(flags);    rtr_lsa_hdr.rtr_num         = htons(num);    rtr_lsa_hdr.rtr_link_id     = htonl(id);    rtr_lsa_hdr.rtr_link_data   = htonl(data);    rtr_lsa_hdr.rtr_type        = type;    rtr_lsa_hdr.rtr_tos_num     = tos;    rtr_lsa_hdr.rtr_metric      = htons(metric);    n = libnet_pblock_append(l, p, (u_int8_t *)&rtr_lsa_hdr, LIBNET_OSPF_LS_RTR_H);    if (n == -1)    {        goto bad;    }    if ((payload && !payload_s) || (!payload && payload_s))    {         snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,			     "%s(): payload inconsistency\n", __func__);        goto bad;    }     if (payload && payload_s)    {        n = libnet_pblock_append(l, p, payload, payload_s);        if (n == -1)        {            goto bad;        }    }    return (ptag ? ptag : libnet_pblock_update(l, p, h,             LIBNET_PBLOCK_LS_RTR_H));bad:    libnet_pblock_delete(l, p);    return (-1);}libnet_ptag_tlibnet_build_ospfv2_lsa_net(u_int32_t nmask, u_int rtrid, u_int8_t *payload,             u_int32_t payload_s, libnet_t *l, libnet_ptag_t ptag){    u_int32_t n, h;    libnet_pblock_t *p;    struct libnet_net_lsa_hdr net_lsa_hdr;    if (l == NULL)    {         return (-1);    }     n = LIBNET_OSPF_LS_NET_H + payload_s;    h = 0;    /*     *  Find the existing protocol block if a ptag is specified, or create     *  a new one.     */    p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_LS_NET_H);    if (p == NULL)    {        return (-1);    }	memset(&net_lsa_hdr, 0, sizeof(net_lsa_hdr));	net_lsa_hdr.net_nmask.s_addr    = htonl(nmask);    net_lsa_hdr.net_rtr_id          = htonl(rtrid);    n = libnet_pblock_append(l, p, (u_int8_t *)&net_lsa_hdr, LIBNET_OSPF_LS_NET_H);    if (n == -1)    {        goto bad;    }    if ((payload && !payload_s) || (!payload && payload_s))    {         snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,			     "%s(): payload inconsistency\n", __func__);        goto bad;    }     if (payload && payload_s)    {        n = libnet_pblock_append(l, p, payload, payload_s);        if (n == -1)        {            goto bad;        }    }    return (ptag ? ptag : libnet_pblock_update(l, p, h,             LIBNET_PBLOCK_LS_NET_H));bad:    libnet_pblock_delete(l, p);    return (-1);}libnet_ptag_tlibnet_build_ospfv2_lsa_sum(u_int32_t nmask, u_int metric, u_int tos,             u_int8_t *payload, u_int32_t payload_s, libnet_t *l, libnet_ptag_t ptag){    u_int32_t n, h;    libnet_pblock_t *p;    struct libnet_sum_lsa_hdr sum_lsa_hdr;    if (l == NULL)    {         return (-1);    }     n = LIBNET_OSPF_LS_SUM_H + payload_s;    h = 0;    /*     *  Find the existing protocol block if a ptag is specified, or create     *  a new one.     */    p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_LS_SUM_H);    if (p == NULL)    {        return (-1);    }	memset(&sum_lsa_hdr, 0, sizeof(sum_lsa_hdr));	sum_lsa_hdr.sum_nmask.s_addr    = htonl(nmask);    sum_lsa_hdr.sum_metric          = htonl(metric);    sum_lsa_hdr.sum_tos_metric      = htonl(tos);    n = libnet_pblock_append(l, p, (u_int8_t *)&sum_lsa_hdr, LIBNET_OSPF_LS_SUM_H);    if (n == -1)    {        goto bad;    }    if ((payload && !payload_s) || (!payload && payload_s))    {        snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,			    "%s(): payload inconsistency\n", __func__);        goto bad;    }     if (payload && payload_s)    {        n = libnet_pblock_append(l, p, payload, payload_s);        if (n == -1)        {           goto bad;        }    }    return (ptag ? ptag : libnet_pblock_update(l, p, h,             LIBNET_PBLOCK_LS_SUM_H));bad:    libnet_pblock_delete(l, p);    return (-1);}libnet_ptag_tlibnet_build_ospfv2_lsa_as(u_int32_t nmask, u_int metric, u_int32_t fwdaddr,            u_int tag, u_int8_t *payload, u_int32_t payload_s, libnet_t *l,             libnet_ptag_t ptag){    u_int32_t n, h;    libnet_pblock_t *p;    struct libnet_as_lsa_hdr as_lsa_hdr;    if (l == NULL)    {         return (-1);    }        n = LIBNET_OSPF_LS_AS_EXT_H + payload_s;    h = 0;    /*     *  Find the existing protocol block if a ptag is specified, or create     *  a new one.     */    p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_LS_AS_EXT_H);    if (p == NULL)    {        return (-1);    }	memset(&as_lsa_hdr, 0, sizeof(as_lsa_hdr));	as_lsa_hdr.as_nmask.s_addr      = htonl(nmask);    as_lsa_hdr.as_metric            = htonl(metric);    as_lsa_hdr.as_fwd_addr.s_addr   = htonl(fwdaddr);    as_lsa_hdr.as_rte_tag           = htonl(tag);    n = libnet_pblock_append(l, p, (u_int8_t *)&as_lsa_hdr, LIBNET_OSPF_LS_AS_EXT_H);    if (n == -1)    {        goto bad;    }    if ((payload && !payload_s) || (!payload && payload_s))    {        snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,			    "%s(): payload inconsistency\n", __func__);        goto bad;    }     if (payload && payload_s)    {        n = libnet_pblock_append(l, p, payload, payload_s);        if (n == -1)        {            goto bad;        }    }    return (ptag ? ptag : libnet_pblock_update(l, p, h,             LIBNET_PBLOCK_LS_AS_EXT_H));bad:    libnet_pblock_delete(l, p);    return (-1);}/* EOF */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -