The patch
included in pcsc-lite is from Valtteri Vuorikoski and I will quote his
git commit message in this article.
Use case
"This is similar to the existing filtering support provided by
PCSCLITE_FILTER_IGNORE_READER_NAMES
(Remove and/or customize PC/SC reader names), but allows using the
full range of udev rules to match specific devices. For example, if you
have several Yubikeys and one is attached to a specific USB port that is
being forwarded to a virtual machine (viz. it should not be touched by
programs on the host machine), this facility allows setting a rule to
keep pcscd away from that Yubikey. Yubikeys attached to other ports keep
working normally."
udev
By default pcsc-lite uses libudev to detect readers events (plug or unplug
of a USB reader). The idea is to use a flag set by udev to tell
pcsc-lite to ignore a reader.
Example rule that targets a Yubikey attached to a specific USB port and causes
pcscd to ignore that device:
The KERNEL match targets a USB device attached to port 3 of a hub on
port 2 of USB bus 1, and rule sets property PCSCLITE_IGNORE to cause
the device to be ignored.
You put the above rule is a file /etc/udev/rules.d/foobar.rules and
voila.
Config
To know what value for KERNEL= to use you can run udevadm monitor
and connect a USB reader. You will get something like:
$ udevadmmonitor
monitor will print the received events for:UDEV - the event which udev sends out after rule processingKERNEL - the kernel ueventKERNEL[2022.067560] add /devices/pci0000:00/0000:00:14.0/usb1/1-3 (usb)KERNEL[2022.069016] change /devices/pci0000:00/0000:00:14.0/usb1/1-3 (usb)KERNEL[2022.069332] add /devices/pci0000:00/0000:00:14.0/usb1/1-3/1-3:1.0 (usb)KERNEL[2022.069416] bind /devices/pci0000:00/0000:00:14.0/usb1/1-3 (usb)UDEV [2022.690370] add /devices/pci0000:00/0000:00:14.0/usb1/1-3 (usb)UDEV [2022.695881] change /devices/pci0000:00/0000:00:14.0/usb1/1-3 (usb)UDEV [2022.700310] add /devices/pci0000:00/0000:00:14.0/usb1/1-3/1-3:1.0 (usb)UDEV [2022.728691] bind /devices/pci0000:00/0000:00:14.0/usb1/1-3 (usb)
You can see the "1-3" information to use in the .rules file.
Debug
To debug your configuration and check the new field PCSCLITE_IGNORE is
correctly set you can use udevadm monitor --property and you get
something like:
$ udevadmmonitor--property
monitor will print the received events for:UDEV - the event which udev sends out after rule processingKERNEL - the kernel ueventKERNEL[2265.405075] add /devices/pci0000:00/0000:00:14.0/usb1/1-3 (usb)ACTION=addDEVPATH=/devices/pci0000:00/0000:00:14.0/usb1/1-3SUBSYSTEM=usbDEVNAME=/dev/bus/usb/001/015DEVTYPE=usb_devicePRODUCT=8e6/3437/100TYPE=0/0/0BUSNUM=001DEVNUM=015SEQNUM=4692MAJOR=189MINOR=14[...]UDEV [2266.066186] bind /devices/pci0000:00/0000:00:14.0/usb1/1-3 (usb)ACTION=bindDEVPATH=/devices/pci0000:00/0000:00:14.0/usb1/1-3SUBSYSTEM=usbDEVNAME=/dev/bus/usb/001/015DEVTYPE=usb_deviceDRIVER=usbPRODUCT=8e6/3437/100TYPE=0/0/0BUSNUM=001DEVNUM=015SEQNUM=4695USEC_INITIALIZED=2265405122ID_BUS=usbID_MODEL=USB_SmartCard_ReaderID_MODEL_ENC=USB\x20SmartCard\x20ReaderID_MODEL_ID=3437ID_SERIAL=Gemplus_USB_SmartCard_ReaderID_VENDOR=GemplusID_VENDOR_ENC=GemplusID_VENDOR_ID=08e6ID_REVISION=0100ID_USB_MODEL=USB_SmartCard_ReaderID_USB_MODEL_ENC=USB\x20SmartCard\x20ReaderID_USB_MODEL_ID=3437ID_USB_SERIAL=Gemplus_USB_SmartCard_ReaderID_USB_VENDOR=GemplusID_USB_VENDOR_ENC=GemplusID_USB_VENDOR_ID=08e6ID_USB_REVISION=0100ID_USB_INTERFACES=:0b0000:ID_VENDOR_FROM_DATABASE=Gemalto (was Gemplus)ID_MODEL_FROM_DATABASE=GemPC Twin SmartCard ReaderID_PATH_WITH_USB_REVISION=pci-0000:00:14.0-usbv2-0:3ID_PATH=pci-0000:00:14.0-usb-0:3ID_PATH_TAG=pci-0000_00_14_0-usb-0_3ID_SMARTCARD_READER=1ID_FOR_SEAT=usb-pci-0000_00_14_0-usb-0_3SYSTEMD_WANTS=smartcard.targetSYSTEMD_USER_WANTS=smartcard.targetPCSCLITE_IGNORE=1MAJOR=189MINOR=14TAGS=:uaccess:security-device:seat:systemd:CURRENT_TAGS=:uaccess:security-device:seat:systemd:
In pcscd logs I get:
04337722 [140613033731776] ../src/hotplug_libudev.c:656:HPEstablishUSBNotifications() USB Device add
00000411 [140613033731776] ../src/hotplug_libudev.c:299:get_driver() Looking for a driver for VID: 0x08E6, PID: 0x3437, path: /dev/bus/usb/001/016
00000303 [140613033731776] ../src/hotplug_libudev.c:417:HPAddDevice() Device Gemalto PC Twin Reader at /dev/bus/usb/001/016 (1-3:1.0) has PCSCLITE_IGNORE set: ignored
And I do not see the PC/SC reader with pcsc_scan command:
$ pcsc_scan-r
No reader found.
Conclusion
I am sure you will find other use cases for this new feature.
Thanks to Valtteri Vuorikoski for the patch. If you have ideas of
changes or improvements for pcsc-lite do not hesitate to submit them.
I now have 42 answers. I think 42 is a good number.
My survey had 4 open questions. Some of you entered very specific
and personal information. I will try to not include personal
information in the results. But I am very thankful for your confidence
and the details you shared with me.
Since how long do you use smart cards?
Since how long do you use smart cards?
#
< 1 year
4
1 to 5 years
7
6 to 10 years
10
11 to 15 years
4
16 to 20 years
5
> 20 years
11
I am surprised to have so many users of smart cards for such a long time.
Maybe I should have been more explicit in my question. I have been using
smart cards myself since around 1990 with French public phone cards and
bank cards as a normal user. My question was more, since when do you use
smart cards as a professional?.
It is interesting to see very experienced smart card users and also all
the possible groups of experiences.
Since how long do you read my blog?
Since how long do you read my blog?
#
< 1 year
10
1 to 5 years
8
6 to 10 years
10
11 to 15 years
10
> 16 years
3
This question has a trap. My blog started in 2000, so the oldest article
is 15 years old. It is not possible to read it since more than 16 years.
The distribution of results is fairly even.
What is your activity?
What is your activity?
#
%
developer
32
78,0 %
Other
10
24,4 %
project manager
5
12,2 %
sales
1
2,4 %
CEO
1
2,4 %
With no real surprise, the vast majority of my readers are developers.
This is not surprising since the majority of the blog content is about
programs and programming interfaces.
In the "other" category, we have:
sysadmin
manufacturer
functional and technical expert
driver packager
How do you read/find my blog?
How do you read/find my blog?
#
%
Redirected by a search engine
17
41,5 %
Redirected by an email
13
31,7 %
RSS feed
9
22,0 %
Redirected from a web page
9
22,0 %
Other
5
12,2 %
Many readers find the articles using a search engine. I guess it's the
normal way to find a solution to a problem or some documentation.
I will continue to include references to my blog articles in the emails I
send. I find that writing a blog article is a good way to not write
again and again the same thing.
Firefox Update Scanner (maybe the RSS feed could be used instead?)
What content do you like?
What content do you like?
#
%
technical explanation of a new feature
39
95,1 %
new software release announcement
25
61,0 %
how to use a function
21
51,2 %
sample codes
20
48,8 %
macOS issues
17
41,5 %
Windows issues
13
31,7 %
pictures of my holidays
4
9,8 %
No surprise, with a large part of developers, the main interest is in
technical explanations and new software announcements.
I am happy to see that few people are looking for content about Windows
issues.
Some people are looking for news about my holidays. That is nice, but I
do not plan to share many photos here. Great game contest: Where was
the picture below taken?
Free form
Thanks for your answers in the free forms.
What content would you like to find on my blog?
In no specific order:
news about pcsc-lite
more details about PC/SC and Smartcard
sample code and technical explanations
Yes, of course.
more card specific stuff like reading passport information or
discussing a bit about EMV processing
My expertise lies more in PKI cards. I agree that it's interesting to have
more details on common cards like EMV, passport or ID cards.
chart of specifics/features/bugs between smartcard readers, cards and
OS/driver versions
I started in the smart card industry in 1997. At first, it was
difficult to use a smart card on a GNU/Linux system. I started by
writing a driver for a serial smart card reader, then submitted
patches to pcsc-lite and continued developing different smart card
related software.
Conclusion
Do not expect posts about my holidays or my life.
I will continue to publish technical articles. If you know about a subject
and want to share your knowledge, I am open to co-author articles. If you
wrote a Free Software program or library that uses a smart card, I can
take a look and write about it.
In any case you can contact me. My e-mail address is available from
About me.
RSS (RDF Site Summary or Really Simple Syndication) is a web feed
that allows users and applications to access updates to websites in
a standardized, computer-readable format. Subscribing to RSS feeds
can allow a user to keep track of many different websites in a
single news aggregator, which constantly monitors sites for new
content, removing the need for the user to manually check them. News
aggregators (or "RSS readers") can be built into a browser,
installed on a desktop computer, or installed on a mobile device.
If you don't want to miss any article from my blog then RSS is a very
good solution for that.
For example I use NewsBlur to read my
different RSS feeds either on my desktop browsers or on my smart phone.
NewsBlur manages the status of all the articles so I do not see again an
article I have already read.
You can also use RSS Parot (Turn Mastodon
into your feed reader) if you want to be notified on your Fediverse account (Mastodon for
example) of new publications.
I prepared a short survey at blog.apdu.fr readers (thanks to
Framasoft for the
survey/Framaforms service). Please take a
few minutes to answer the survey so I can improve the blog.
I plan to keep the survey open for about one month. After that I will
publish a summary here. If you want me to keep your answers private
please indicate it.
Since May 2023 I host the blog myself (on my own server using my own
domain name) and no more on Google blogger servers. I am very happy
with this change.
Statistics
For 2024 the blog served 225977 pages (~25 pages per hour) for a total of 26.41 GB.