Dalam proses menulis pemacu Linux, teknologi pemberitahuan tak segerak ialah teknologi yang sangat penting. Ia boleh mencapai pemprosesan acara dan penghantaran data yang cekap, meningkatkan prestasi sistem dan kelajuan tindak balas. Dalam artikel ini, kami akan menyelidiki prinsip pelaksanaan dan teknologi berkaitan teknologi pemacu Linux (4) _teknologi pemberitahuan tak segerak.
Nama penuh pemberitahuan tak segerak ialah "IO tak segerak dipacu isyarat" Melalui kaedah "isyarat", apabila sumber yang dijangka diperoleh tersedia, pemandu akan secara aktif memberitahu aplikasi yang ditentukan, sepadan dengan "isyarat" bagi lapisan aplikasi, digunakan di sini Ia adalah isyarat "SIGIO". Langkahnya ialah
Rangka kerja keseluruhan mekanisme:
“
”
Seperti isyarat lain, lapisan aplikasi perlu mendaftarkan fungsi pemprosesan isyarat,
Cara mendaftar masih menggunakan signal() atau sigaction()
Selain itu, lapisan aplikasi juga perlu menambah sendiri pada senarai rantai pemberitahuan pemandu Kod yang ditambah adalah seperti berikut
fcntl(dev_fd,F_SETOWN,getpid()); int oflags = fcntl(dev_fd,F_GETFL); fcntl(dev_fd,F_SETFL,oflags|FASYNC); ... while(1);
Setelah selesai kerja di atas, program lapisan aplikasi boleh menunggu ketibaan SIGIO.
Selepas lapisan aplikasi didaftarkan, penghantaran terakhir bergantung pada kaedah pemprosesan pemacu peranti Untuk menjadikan peranti menyokong mekanisme pemberitahuan tak segerak, merujuk kepada antara muka lapisan aplikasi, pemandu melibatkan tiga tugas.
, strukturnya ialah struct fasync_struct, dan fungsinya ialah fasync_helper() dan kill_fasync()
struct fasync_struct {
spinlock_t fa_lock;
int magic;
int fa_fd;
struct fasync_struct *fa_next; /* singly linked list */
struct file *fa_file;
struct rcu_head fa_rcu;
};
adalah untuk mendaftarkan objek fasync_struct ke dalam kernel Apabila lapisan aplikasi melaksanakan **fcntl(dev_fd, F_SETFL, oflags|FASYNC), ia akan memanggil semula fops pemandu. fasync(), jadi Biasanya letakkan fasync_helper() ke dalam pelaksanaan fasync()**.
/**
*fasync_helper - 将一个fasync_struct对象注册进内核
*@fd:文件描述符,由fasync传入
*@filp:file指针,由fasync传入
*@sig:信号类型,通常使用的就是SIGIO
*@dev_fasync:事前准备的fasync_struct对象指针的指针
*/
int fasync_helper(int fd, struct file * filp, int sig, struct fasync_struct ** dev_fasync);
/** *kill_fasync - 释放一个信号 *@dev_fasync:事前使用fasync_helper注册进内核的fasync_struct对象指针的指针 *@filp:file指针,由fasync传入 *@sig:信号类型,通常使用的就是SIGIO *@flag:标志,通常,如果资源可读用POLLIN,如果资源可写用POLLOUT */ void kill_fasync(struct fasync_struct **dev_fasync, int sig, int flag);
static struct fasync_struct *fasync = NULL; static irqreturn_t handler(int irq, void *dev) { kill_fasync(&fasync, SIGIO, POLLIN); return IRQ_HANDLED; } static int demo_fasync(int fd, struct file *filp, int mode) { return fasync_helper(fd, filp, mode, &fasync); } struct file_operations fops = { ... .fasync = demo_fasync, ... } static int __init demo_init(void) { ... request_irq(irq, handler, IRQF_TRIGGER_RISING, "demo", NULL); ... }
总之,异步通知技术是Linux驱动程序编写过程中不可或缺的一部分。它可以实现高效的事件处理和数据传输,提高系统的性能和响应速度。希望本文能够帮助读者更好地理解Linux驱动技术(四) _异步通知技术的实现原理和相关技术。
Atas ialah kandungan terperinci Perbincangan mendalam tentang teknologi pemacu Linux (4)_Prinsip pelaksanaan dan teknologi berkaitan teknologi pemberitahuan tak segerak. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!