色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

分析協(xié)議層注冊(cè)進(jìn)內(nèi)核以及被socket的過(guò)程

B4Pb_gh_6fde77c ? 來(lái)源:Linux內(nèi)核之旅 ? 作者:陳莉君 ? 2021-08-04 16:13 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1. 前言

本文首先從宏觀上概述了數(shù)據(jù)包發(fā)送的流程,接著分析了協(xié)議層注冊(cè)進(jìn)內(nèi)核以及被socket的過(guò)程,最后介紹了通過(guò) socket 發(fā)送網(wǎng)絡(luò)數(shù)據(jù)的過(guò)程。

2. 數(shù)據(jù)包發(fā)送宏觀視角

從宏觀上看,一個(gè)數(shù)據(jù)包從用戶程序到達(dá)硬件網(wǎng)卡的整個(gè)過(guò)程如下:

使用系統(tǒng)調(diào)用(如 sendto,sendmsg 等)寫(xiě)數(shù)據(jù)

數(shù)據(jù)穿過(guò)socket 子系統(tǒng),進(jìn)入socket 協(xié)議族(protocol family)系統(tǒng)

協(xié)議族處理:數(shù)據(jù)穿過(guò)協(xié)議層,這一過(guò)程(在許多情況下)會(huì)將數(shù)據(jù)(data)轉(zhuǎn)換成數(shù)據(jù)包(packet)

數(shù)據(jù)穿過(guò)路由層,這會(huì)涉及路由緩存和 ARP 緩存的更新;如果目的 MAC 不在 ARP 緩存表中,將觸發(fā)一次 ARP 廣播來(lái)查找 MAC 地址

穿過(guò)協(xié)議層,packet 到達(dá)設(shè)備無(wú)關(guān)層(device agnostic layer)

使用 XPS(如果啟用)或散列函數(shù)選擇發(fā)送隊(duì)列

調(diào)用網(wǎng)卡驅(qū)動(dòng)的發(fā)送函數(shù)

數(shù)據(jù)傳送到網(wǎng)卡的 qdisc(queue discipline,排隊(duì)規(guī)則)

qdisc 會(huì)直接發(fā)送數(shù)據(jù)(如果可以),或者將其放到隊(duì)列,下次觸發(fā)NET_TX 類型軟中斷(softirq)的時(shí)候再發(fā)送

數(shù)據(jù)從 qdisc 傳送給驅(qū)動(dòng)程序

驅(qū)動(dòng)程序創(chuàng)建所需的DMA 映射,以便網(wǎng)卡從 RAM 讀取數(shù)據(jù)

驅(qū)動(dòng)向網(wǎng)卡發(fā)送信號(hào),通知數(shù)據(jù)可以發(fā)送了

網(wǎng)卡從 RAM 中獲取數(shù)據(jù)并發(fā)送

發(fā)送完成后,設(shè)備觸發(fā)一個(gè)硬中斷(IRQ),表示發(fā)送完成

硬中斷處理函數(shù)被喚醒執(zhí)行。對(duì)許多設(shè)備來(lái)說(shuō),這會(huì)觸發(fā) NET_RX 類型的軟中斷,然后 NAPI poll 循環(huán)開(kāi)始收包

poll 函數(shù)會(huì)調(diào)用驅(qū)動(dòng)程序的相應(yīng)函數(shù),解除 DMA 映射,釋放數(shù)據(jù)

3. 協(xié)議層注冊(cè)

協(xié)議層分析我們將關(guān)注 IP 和 UDP 層,其他協(xié)議層可參考這個(gè)過(guò)程。我們首先來(lái)看協(xié)議族是如何注冊(cè)到內(nèi)核,并被 socket 子系統(tǒng)使用的。

當(dāng)用戶程序像下面這樣創(chuàng)建 UDP socket 時(shí)會(huì)發(fā)生什么?

sock = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP)

簡(jiǎn)單來(lái)說(shuō),內(nèi)核會(huì)去查找由 UDP 協(xié)議棧導(dǎo)出的一組函數(shù)(其中包括用于發(fā)送和接收網(wǎng)絡(luò)數(shù)據(jù)的函數(shù)),并賦給 socket 的相應(yīng)字段。準(zhǔn)確理解這個(gè)過(guò)程需要查看 AF_INET 地址族的代碼。

內(nèi)核初始化的很早階段就執(zhí)行了 inet_init 函數(shù),這個(gè)函數(shù)會(huì)注冊(cè) AF_INET 協(xié)議族 ,以及該協(xié)議族內(nèi)的各協(xié)議棧(TCP,UDP,ICMP 和 RAW),并調(diào)用初始化函數(shù)使協(xié)議棧準(zhǔn)備好處理網(wǎng)絡(luò)數(shù)據(jù)。inet_init 定義在net/ipv4/af_inet.c 。

AF_INET 協(xié)議族導(dǎo)出一個(gè)包含 create 方法的 struct net_proto_family 類型實(shí)例。當(dāng)從用戶程序創(chuàng)建 socket 時(shí),內(nèi)核會(huì)調(diào)用此方法:

static const struct net_proto_family inet_family_ops = {

.family = PF_INET,

.create = inet_create,

.owner = THIS_MODULE,

};

inet_create 根據(jù)傳遞的 socket 參數(shù),在已注冊(cè)的協(xié)議中查找對(duì)應(yīng)的協(xié)議:

/* Look for the requested type/protocol pair. */

lookup_protocol:

err = -ESOCKTNOSUPPORT;

rcu_read_lock();

list_for_each_entry_rcu(answer, &inetsw[sock-》type], list) {

err = 0;

/* Check the non-wild match. */

if (protocol == answer-》protocol) {

if (protocol != IPPROTO_IP)

break;

} else {

/* Check for the two wild cases. */

if (IPPROTO_IP == protocol) {

protocol = answer-》protocol;

break;

}

if (IPPROTO_IP == answer-》protocol)

break;

}

err = -EPROTONOSUPPORT;

}

然后,將該協(xié)議的回調(diào)方法(集合)賦給這個(gè)新創(chuàng)建的 socket:

sock-》ops = answer-》ops;

可以在 af_inet.c 中看到所有協(xié)議的初始化參數(shù)。下面是TCP 和 UDP的初始化參數(shù):

/* Upon startup we insert all the elements in inetsw_array[] into

* the linked list inetsw.

*/

static struct inet_protosw inetsw_array[] =

{

{

.type = SOCK_STREAM,

.protocol = IPPROTO_TCP,

.prot = &tcp_prot,

.ops = &inet_stream_ops,

.no_check = 0,

.flags = INET_PROTOSW_PERMANENT |

INET_PROTOSW_ICSK,

},

{

.type = SOCK_DGRAM,

.protocol = IPPROTO_UDP,

.prot = &udp_prot,

.ops = &inet_dgram_ops,

.no_check = UDP_CSUM_DEFAULT,

.flags = INET_PROTOSW_PERMANENT,

},

/* 。。。。 more protocols 。。。 */

IPPROTO_UDP 協(xié)議類型有一個(gè) ops 變量,包含很多信息,包括用于發(fā)送和接收數(shù)據(jù)的回調(diào)函數(shù):

const struct proto_ops inet_dgram_ops = {

.family = PF_INET,

.owner = THIS_MODULE,

/* 。。。 */

.sendmsg = inet_sendmsg,

.recvmsg = inet_recvmsg,

/* 。。。 */

};

EXPORT_SYMBOL(inet_dgram_ops);

prot 字段指向一個(gè)協(xié)議相關(guān)的變量(的地址),對(duì)于 UDP 協(xié)議,其中包含了 UDP 相關(guān)的回調(diào)函數(shù)。UDP 協(xié)議對(duì)應(yīng)的 prot 變量為 udp_prot,定義在 net/ipv4/udp.c:

struct proto udp_prot = {

.name = “UDP”,

.owner = THIS_MODULE,

/* 。。。 */

.sendmsg = udp_sendmsg,

.recvmsg = udp_recvmsg,

/* 。。。 */

};

EXPORT_SYMBOL(udp_prot);

現(xiàn)在,讓我們轉(zhuǎn)向發(fā)送 UDP 數(shù)據(jù)的用戶程序,看看 udp_sendmsg 是如何在內(nèi)核中被調(diào)用的。

4. 通過(guò) socket 發(fā)送網(wǎng)絡(luò)數(shù)據(jù)

用戶程序想發(fā)送 UDP 網(wǎng)絡(luò)數(shù)據(jù),因此它使用 sendto 系統(tǒng)調(diào)用:

ret = sendto(socket, buffer, buflen, 0, &dest, sizeof(dest));

該系統(tǒng)調(diào)用穿過(guò)Linux 系統(tǒng)調(diào)用(system call)層,最后到達(dá)net/socket.c中的這個(gè)函數(shù):

/*

* Send a datagram to a given address. We move the address into kernel

* space and check the user space data area is readable before invoking

* the protocol.

*/

SYSCALL_DEFINE6(sendto, int, fd, void __user *, buff, size_t, len,

unsigned int, flags, struct sockaddr __user *, addr,

int, addr_len)

{

/* 。。。 code 。。。 */

err = sock_sendmsg(sock, &msg, len);

/* 。。。 code 。。。 */

}

SYSCALL_DEFINE6 宏會(huì)展開(kāi)成一堆宏,后者經(jīng)過(guò)一波復(fù)雜操作創(chuàng)建出一個(gè)帶 6 個(gè)參數(shù)的系統(tǒng)調(diào)用(因此叫 DEFINE6)。作為結(jié)果之一,會(huì)看到內(nèi)核中的所有系統(tǒng)調(diào)用都帶 sys_前綴。

sendto 代碼會(huì)先將數(shù)據(jù)整理成底層可以處理的格式,然后調(diào)用 sock_sendmsg。特別地, 它將傳遞給 sendto 的地址放到另一個(gè)變量(msg)中:

iov.iov_base = buff;

iov.iov_len = len;

msg.msg_name = NULL;

msg.msg_iov = &iov;

msg.msg_iovlen = 1;

msg.msg_control = NULL;

msg.msg_controllen = 0;

msg.msg_namelen = 0;

if (addr) {

err = move_addr_to_kernel(addr, addr_len, &address);

if (err 《 0)

goto out_put;

msg.msg_name = (struct sockaddr *)&address;

msg.msg_namelen = addr_len;

}

這段代碼將用戶程序傳入到內(nèi)核的(存放待發(fā)送數(shù)據(jù)的)地址,作為 msg_name 字段嵌入到 struct msghdr 類型變量中。這和用戶程序直接調(diào)用 sendmsg 而不是 sendto 發(fā)送數(shù)據(jù)差不多,這之所以可行,是因?yàn)?sendto 和 sendmsg 底層都會(huì)調(diào)用 sock_sendmsg。

4.1 sock_sendmsg, __sock_sendmsg, __sock_sendmsg_nosec

sock_sendmsg 做一些錯(cuò)誤檢查,然后調(diào)用__sock_sendmsg;后者做一些自己的錯(cuò)誤檢查 ,然后調(diào)用__sock_sendmsg_nosec。__sock_sendmsg_nosec 將數(shù)據(jù)傳遞到 socket 子系統(tǒng)的更深處:

static inline int __sock_sendmsg_nosec(struct kiocb *iocb, struct socket *sock,

struct msghdr *msg, size_t size)

{

struct sock_iocb *si = 。。。。

/* other code 。。。 */

return sock-》ops-》sendmsg(iocb, sock, msg, size);

}

通過(guò)前面介紹的 socket 創(chuàng)建過(guò)程,可以知道注冊(cè)到這里的 sendmsg 方法就是 inet_sendmsg。

4.2 inet_sendmsg

從名字可以猜到,這是 AF_INET 協(xié)議族提供的通用函數(shù)。此函數(shù)首先調(diào)用 sock_rps_record_flow 來(lái)記錄最后一個(gè)處理該(數(shù)據(jù)所屬的)flow 的 CPU; Receive Packet Steering 會(huì)用到這個(gè)信息。接下來(lái),調(diào)用 socket 的協(xié)議類型(本例是 UDP)對(duì)應(yīng)的 sendmsg 方法:

int inet_sendmsg(struct kiocb *iocb, struct socket *sock, struct msghdr *msg,

size_t size)

{

struct sock *sk = sock-》sk;

sock_rps_record_flow(sk);

/* We may need to bind the socket. */

if (!inet_sk(sk)-》inet_num && !sk-》sk_prot-》no_autobind && inet_autobind(sk))

return -EAGAIN;

return sk-》sk_prot-》sendmsg(iocb, sk, msg, size);

}

EXPORT_SYMBOL(inet_sendmsg);

本例是 UDP 協(xié)議,因此上面的 sk-》sk_prot-》sendmsg 指向的是之前看到的(通過(guò) udp_prot 導(dǎo)出的)udp_sendmsg 函數(shù)。

sendmsg()函數(shù)作為分界點(diǎn),處理邏輯從 AF_INET 協(xié)議族通用處理轉(zhuǎn)移到具體的 UDP 協(xié)議的處理。

5. 總結(jié)

了解Linux內(nèi)核網(wǎng)絡(luò)數(shù)據(jù)包發(fā)送的詳細(xì)過(guò)程,有助于我們進(jìn)行網(wǎng)絡(luò)監(jiān)控和調(diào)優(yōu)。本文只分析了協(xié)議層的注冊(cè)和通過(guò) socket 發(fā)送數(shù)據(jù)的過(guò)程,數(shù)據(jù)在傳輸層和網(wǎng)絡(luò)層的詳細(xì)發(fā)送過(guò)程將在下一篇文章中分析。

參考鏈接:

[1] https://blog.packagecloud.io/eng/2017/02/06/monitoring-tuning-linux-networking-stack-sending-data

[2] https://segmentfault.com/a/1190000008926093

本系列文章1-4,來(lái)源于陳莉君老師公眾號(hào)“Linux內(nèi)核之旅”

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 內(nèi)核
    +關(guān)注

    關(guān)注

    3

    文章

    1417

    瀏覽量

    41496

原文標(biāo)題:Linux內(nèi)核網(wǎng)絡(luò)udp數(shù)據(jù)包發(fā)送(一)

文章出處:【微信號(hào):gh_6fde77c41971,微信公眾號(hào):FPGA干貨】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 0人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    嵌入式學(xué)習(xí)-飛凌嵌入式ElfBoard ELF 1板卡-CAN編程示例之socket CAN

    空間的socket接口,它構(gòu)建于Linux網(wǎng)絡(luò)之上,因此可以直接使用已有的隊(duì)列功能。CAN控制器的設(shè)備驅(qū)動(dòng)將自己作為一個(gè)網(wǎng)絡(luò)設(shè)備注冊(cè)進(jìn)Linux的網(wǎng)絡(luò)
    發(fā)表于 11-15 09:25

    飛凌嵌入式ElfBoard ELF 1板卡-CAN編程示例之socket CAN

    空間的socket接口,它構(gòu)建于Linux網(wǎng)絡(luò)之上,因此可以直接使用已有的隊(duì)列功能。CAN控制器的設(shè)備驅(qū)動(dòng)將自己作為一個(gè)網(wǎng)絡(luò)設(shè)備注冊(cè)進(jìn)Linux的網(wǎng)絡(luò)
    發(fā)表于 11-14 08:51

    socket 和 UDP 協(xié)議的對(duì)比

    Socket 定義 Socket 是一個(gè)抽象,它提供了一種方式,使得應(yīng)用程序能夠發(fā)送和接收數(shù)據(jù)。在網(wǎng)絡(luò)編程中,Socket 允許程序創(chuàng)建一個(gè)通信端點(diǎn),通過(guò)這個(gè)端點(diǎn),程序可以與其他
    的頭像 發(fā)表于 11-12 14:28 ?935次閱讀

    socket 加密通信的實(shí)現(xiàn)方式

    )和 TLS(Transport Layer Security)是實(shí)現(xiàn) Socket 加密通信最常用的協(xié)議。它們?cè)趥鬏?b class='flag-5'>層之上提供了加密、認(rèn)證和完整性保護(hù)。 實(shí)現(xiàn)步驟: 握手階段: 客戶端和服務(wù)器通過(guò)
    的頭像 發(fā)表于 11-12 14:18 ?1516次閱讀

    socket 與 HTTP 協(xié)議的關(guān)系

    在計(jì)算機(jī)網(wǎng)絡(luò)中,Socket和HTTP協(xié)議是兩個(gè)非常重要的概念,它們?cè)跀?shù)據(jù)傳輸和網(wǎng)絡(luò)通信中扮演著關(guān)鍵的角色。 1. Socket的概念 Socket是一種通信機(jī)制,它允許兩個(gè)程序(一個(gè)
    的頭像 發(fā)表于 11-12 14:12 ?807次閱讀

    socket 網(wǎng)絡(luò)通信協(xié)議解析

    在現(xiàn)代計(jì)算機(jī)科學(xué)中,網(wǎng)絡(luò)通信是信息交換的核心。Socket(套接字)是網(wǎng)絡(luò)通信中一個(gè)至關(guān)重要的概念,它提供了一種抽象,使得程序能夠發(fā)送和接收數(shù)據(jù)。 1. Socket的基本概念 Socket
    的頭像 發(fā)表于 11-12 14:04 ?5580次閱讀

    socket 編程基礎(chǔ)入門(mén)

    Socket 編程基礎(chǔ)入門(mén) 在計(jì)算機(jī)網(wǎng)絡(luò)中,Socket 是一個(gè)抽象,它將網(wǎng)絡(luò)通信的細(xì)節(jié)隱藏起來(lái),為開(kāi)發(fā)者提供了一個(gè)簡(jiǎn)單的接口來(lái)發(fā)送和接收數(shù)據(jù)。Socket 編程是網(wǎng)絡(luò)編程的基礎(chǔ),它
    的頭像 發(fā)表于 11-12 14:03 ?1073次閱讀

    socket連接超時(shí)如何處理

    實(shí)現(xiàn)以及網(wǎng)絡(luò)環(huán)境。 1. 理解Socket連接超時(shí) 在TCP/IP協(xié)議中,socket連接超時(shí)通常指的是在建立連接、發(fā)送數(shù)據(jù)或接收數(shù)據(jù)的過(guò)程
    的頭像 發(fā)表于 11-01 16:48 ?2439次閱讀

    socket與HTTP協(xié)議的比較

    (套接字)是一種通信機(jī)制,它允許兩個(gè)應(yīng)用程序通過(guò)網(wǎng)絡(luò)進(jìn)行雙向通信。在TCP/IP模型中,Socket位于傳輸和應(yīng)用之間,提供了一種抽象的接口,使得應(yīng)用程序可以忽略底層網(wǎng)絡(luò)的細(xì)節(jié),專注于數(shù)據(jù)的發(fā)送和接收。 1.2 HTTP
    的頭像 發(fā)表于 11-01 16:14 ?959次閱讀

    如何在Python中使用socket

    1. 基本概念 在開(kāi)始使用socket之前,我們需要了解一些基本的網(wǎng)絡(luò)通信概念: IP地址 :用于標(biāo)識(shí)網(wǎng)絡(luò)上的設(shè)備。 端口 :用于標(biāo)識(shí)設(shè)備上的特定服務(wù)。 協(xié)議 :用于規(guī)定數(shù)據(jù)傳輸?shù)囊?guī)則,如TCP
    的頭像 發(fā)表于 11-01 16:10 ?772次閱讀

    什么是socket編程 socket與tcp/ip協(xié)議的關(guān)系

    基于TCP/IP協(xié)議族,這是一組用于網(wǎng)絡(luò)通信的協(xié)議,包括傳輸控制協(xié)議(TCP)和互聯(lián)網(wǎng)協(xié)議(IP)。 Socket與TCP/IP
    的頭像 發(fā)表于 11-01 16:01 ?1253次閱讀

    SATA主機(jī)協(xié)議的物理的實(shí)現(xiàn)過(guò)程

    這里講解SATA主機(jī)協(xié)議的物理的實(shí)現(xiàn)過(guò)程
    的頭像 發(fā)表于 10-22 15:17 ?1038次閱讀
    SATA主機(jī)<b class='flag-5'>協(xié)議</b>的物理<b class='flag-5'>層</b>的實(shí)現(xiàn)<b class='flag-5'>過(guò)程</b>

    物聯(lián)網(wǎng)4G CAT1產(chǎn)品的Socket通訊研發(fā)測(cè)試方案

    01 物聯(lián)網(wǎng)行業(yè)中存在問(wèn)題 研發(fā)階段,4G CAT1產(chǎn)品Socket通信測(cè)試. 02 該問(wèn)題帶來(lái)的危害及影響 Socket是應(yīng)用與TCP/IP協(xié)議族通信的中間軟件抽象
    的頭像 發(fā)表于 09-29 17:21 ?1008次閱讀
    物聯(lián)網(wǎng)4G CAT1產(chǎn)品的<b class='flag-5'>Socket</b>通訊研發(fā)測(cè)試方案

    socket和http區(qū)別是什么

    Socket和HTTP是兩種不同的網(wǎng)絡(luò)通信協(xié)議,它們?cè)诰W(wǎng)絡(luò)編程中扮演著重要的角色。 定義 Socket(套接字)是一種通信端點(diǎn),它提供了一個(gè)抽象,使得進(jìn)程能夠通過(guò)網(wǎng)絡(luò)進(jìn)行通信。
    的頭像 發(fā)表于 08-16 11:04 ?1608次閱讀

    如何理解socket編程接口

    不同計(jì)算機(jī)之間進(jìn)行通信的方法。在網(wǎng)絡(luò)編程中,Socket廣泛用于實(shí)現(xiàn)客戶端和服務(wù)器之間的通信。 1.2 Socket的分類 根據(jù)通信方式的不同,Socket可以分為兩大類:流式
    的頭像 發(fā)表于 08-16 10:48 ?953次閱讀
    主站蜘蛛池模板: 亚洲日韩有码无线免费 | 农民下乡在线观看3 | 亚洲第一成年网站视频 | 亚洲高清中文字幕 | 国产传媒18精品免费观看 | 中文字幕在线观看亚洲 | 么公在浴室了我的奶 | 国产成人精品免费青青草原app | 亚洲精品免费在线 | 丝瓜影院观看免费高清国际观察 | 亚洲中文字幕无码爆乳APP | 久久草香蕉频线观 | 日日夜夜操操操 | 24小时日本在线电影 | 九九热免费在线观看 | 欧洲亚洲精品A片久久99果冻 | 四虎国产精品免费观看视频 | 父皇轻点插好疼H限 | 97视频免费上传播放 | 在线亚洲免费 | bbwvideoa欧美老妇| 亚洲黄色在线播放 | 亚洲高清中文字幕免费 | 久久久97人妻无码精品蜜桃 | 午夜性伦鲁啊鲁免费视频 | 福利一区福利二区 | 好男人午夜www视频在线观看 | 大桥未久电影在线观看 | 69xx欧美 | 人妻美妇疯狂迎合 | 久久亚洲A片COM人成A | 国产色偷偷男人的天堂 | 无码日韩人妻精品久久蜜桃入口 | 黑人猛挺进小莹的体内视频 | 最近的中文字幕2019国语 | 国产精品内射久久久久欢欢 | 亚洲AV成人片色在线观看网站 | 综合久久久久久久综合网 | 伊人久久中文 | 好硬好湿好大再深一点动态图 | 日韩亚洲欧美中文高清 |

    電子發(fā)燒友

    中國(guó)電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會(huì)員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品