In the previous example character driver code <character driver sample>, we used the “mknod command” to create the device file instance. it is possible to create a device file instance via code in the driver itself allowing the code to come up “on the go”.
The below code snippet provides an example implementation of the same.
data:image/s3,"s3://crabby-images/b2991/b2991f376782cdad5889b029702cc5fd59f34546" alt=""
The above code has two specific calls “device_create” and “class_create”. The device_create API creates a dev file and a the newly formed dev file will have an entry in sysfs. the “class_create” API is used to create a class entry under which the the device file is created.
The /sys/class output before and after the character driver is loaded is provided below
data:image/s3,"s3://crabby-images/f257e/f257ef7c5cdbd303b97032b98ac30f77f0ae1544" alt=""
As can be seen in the above output, a class folder entry is created in the /sys/class folder and a device file is created in the /sys/device folder. An entry in the /dev folder is also created which is the device file as shown below
data:image/s3,"s3://crabby-images/434c4/434c4297b1667a436bf33849d2092ec2475e4213" alt=""
The Character driver is now ready for access. The device can be accessed via the same sample code snippet provided in the previous article <Sample code for Character device driver>. The output of the sample code and dmesg output are placed below
data:image/s3,"s3://crabby-images/acdf0/acdf0765690db5e29403407c5ac4a01cb5a8bf03" alt=""
In the next article, we will look at miscellaneous drivers
Pingback: Character device driver sample user space code | Hitch Hiker's Guide to Learning