Re: libcamcontrol ?
- In reply to: Gleb Popov : "libcamcontrol ?"
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Tue, 17 Jan 2023 15:18:43 UTC
On Tue, Jan 17, 2023 at 2:42 AM Gleb Popov <arrowd@freebsd.org> wrote: > I wonder if it makes sense to move some code from > sbin/camcontrol/camcontrol.c to a shared library. Specifically, all > the entry points of the main executable like "devlist", "identify", > etc. and all the code supporting them. > Right now there's a number of routines that are in libcam that implement talking to the drive, but none that interpret the data in any meaningful way, at least in a user userful form. However, the interface to libcam is fairly low level, and assumes the caller takes care of a lot of details, so there's a fair amount of code repetition even within camcontrol. Some additional features in libcam likely could help clean things up for camcontrol as well. I'm not sure where I'd land between putting this in a new library, and having it be just inside of libcam, but leaning towards new library... > I'm asking because I require camcontrol functionality in > sysutils/bsdisks and calling the executable doesn't satisfy my needs. > At the same time, the amount of code I pulled out from camcontrol.c > keeps growing [1] and I feel uncomfortable about it. > I can understand that. we already share some of the nvme info printing code between camcontrol and nvmecontrol. It's a bit of a pain. > Another approach might be implementing libxo in the camcontrol utility > and enriching it to return all the information I need. > I've long wanted this. It would make a lot of scripts that we have at $WORK a lot simpler since we do ad-hoc parsing anyway... This might be an easier path to take, honestly, since it would present this structured data with a good external representation that many could use. I started on this a long time ago, though, and didn't have the time to focus on the schema definition needed to make this work well... > I'm volunteering to do the work, but I need a plan. > I'd lean towards libxo. while there are a number of places in the system that have adopted libxo that are dubious at best, there's several it's been a clear win. camcontrol falls into the clear win category, though it's a combination of a control program and a status reporting program. The control parts won't fit well, imho, but the rest will. Warner