Hardware tutorial
- Coconut9
- Member
- Posts: 51
- Joined: Sat May 20, 2017 1:25 am
- Location: PCI bus: 3, slot: 9, function: 5
Hardware tutorial
I would like to learn how to use the camera,audio,network,microphone... (internal on a laptop or from usb generally) is there any tutorial to explain this think?
How people react when a new update of your OS is coming:
Linux user: Cool, more free stuff!
Mac user: Ooh I have to pay!
Windows user: Ah not again!
Linux user: Cool, more free stuff!
Mac user: Ooh I have to pay!
Windows user: Ah not again!
Re: Hardware tutorial
That question is way to general to be answered. Use the search function. Check the wiki for certain hardware components. Start with something easy and then build from that.
managarm: Microkernel-based OS capable of running a Wayland desktop (Discord: https://discord.gg/7WB6Ur3). My OS-dev projects: [mlibc: Portable C library for managarm, qword, Linux, Sigma, ...] [LAI: AML interpreter] [xbstrap: Build system for OS distributions].
- obiwac
- Member
- Posts: 149
- Joined: Fri Jan 27, 2017 12:15 pm
- Libera.chat IRC: obiwac
- Location: Belgium
Re: Hardware tutorial
I don't wanna sound rude or anything, but I don't feel like you are quite ready for osdev yet. You seem to have no clue about how a computer works at a lower level. It's not as easy as you may think it is, judging by your question.
Re: Hardware tutorial
Hi,
My approach is to pick one specific type of thing (e.g. audio), then spend several weeks researching and thinking about the higher level requirements - things like the ability to give sounds a virtual 3D position and possibly trajectory (doppler effect), a way to determine the physical speaker's characteristics (location relative to end user, frequency response curves), a way to map "virtual 3D position of sound" and the pitch of the sound onto available speakers (left/right/front/back, treble/mid-range/bass?), some sort of "sound effect processor" plugins/modules, etc. Then I'd design the higher level parts (the interface that applications would use, something to intelligently direct sounds to whichever sound cards are present, etc). Then I'd design the lower level device driver interface (how device drivers will communicate with the higher level parts).
Once all that is done (and the low level device driver interface is designed) I'd look into writing device drivers, beginning with finding a list of specific devices I have (there's no point writing a device driver that you can't test) then sorting that list in order of best "documentation + market share - complexity" and picking whatever is at the top of the list.
At this point I'll have specification/s for the "device driver software interface" (that I designed) on one side, and specifications/documentation for the "device hardware interface" (that the device manufacturer designed) on the other side. Writing a device driver is mostly about writing whatever glue is needed between these interfaces.
Of course a device driver also depends on "bus specific" things (e.g. PCI enumeration if it's a PCI device, USB enumeration and the interface drivers use to communicate with USB controller drivers if it's a USB device, whatever ugly hack you needed to work around the lack of "plug and play" if it's an ISA device, etc); and will also depend on functionality provided by kernel (some way to communicate, memory management, scheduler, IRQ handling, IO port and memory mapped IO resource management, etc). All of the things that a device driver depends on should exist before you start thinking about writing a device driver.
Cheers,
Brendan
There's no tutorial.ARISTOS wrote:I would like to learn how to use the camera,audio,network,microphone... (internal on a laptop or from usb generally) is there any tutorial to explain this think?
My approach is to pick one specific type of thing (e.g. audio), then spend several weeks researching and thinking about the higher level requirements - things like the ability to give sounds a virtual 3D position and possibly trajectory (doppler effect), a way to determine the physical speaker's characteristics (location relative to end user, frequency response curves), a way to map "virtual 3D position of sound" and the pitch of the sound onto available speakers (left/right/front/back, treble/mid-range/bass?), some sort of "sound effect processor" plugins/modules, etc. Then I'd design the higher level parts (the interface that applications would use, something to intelligently direct sounds to whichever sound cards are present, etc). Then I'd design the lower level device driver interface (how device drivers will communicate with the higher level parts).
Once all that is done (and the low level device driver interface is designed) I'd look into writing device drivers, beginning with finding a list of specific devices I have (there's no point writing a device driver that you can't test) then sorting that list in order of best "documentation + market share - complexity" and picking whatever is at the top of the list.
At this point I'll have specification/s for the "device driver software interface" (that I designed) on one side, and specifications/documentation for the "device hardware interface" (that the device manufacturer designed) on the other side. Writing a device driver is mostly about writing whatever glue is needed between these interfaces.
Of course a device driver also depends on "bus specific" things (e.g. PCI enumeration if it's a PCI device, USB enumeration and the interface drivers use to communicate with USB controller drivers if it's a USB device, whatever ugly hack you needed to work around the lack of "plug and play" if it's an ISA device, etc); and will also depend on functionality provided by kernel (some way to communicate, memory management, scheduler, IRQ handling, IO port and memory mapped IO resource management, etc). All of the things that a device driver depends on should exist before you start thinking about writing a device driver.
Cheers,
Brendan
For all things; perfection is, and will always remain, impossible to achieve in practice. However; by striving for perfection we create things that are as perfect as practically possible. Let the pursuit of perfection be our guide.