I experiment and I wonder...
Now, I have mapped all adresses of memory area from 0x00000000 - 0x000fffff to 0xd0000000 - 0xd000fffff.
Despite this mapping, all the hard ware ports with adresses like 0x60, 0x64, 0x20 0xa0 are accessible as before. I 'm just curious for I tought, they would have to be mapped too. Or am I completely dumb and ignorant about hardware ports?
thank ya for illumination in this issue. I see it runs, but I want to know why. doesn't i386 architecture use memory mapped io?
HW Port adresses and paged memory
-
- Member
- Posts: 1600
- Joined: Wed Oct 18, 2006 11:59 am
- Location: Vienna/Austria
- Contact:
HW Port adresses and paged memory
... the osdever formerly known as beyond infinity ...
BlueillusionOS iso image
BlueillusionOS iso image
- Pype.Clicker
- Member
- Posts: 5964
- Joined: Wed Oct 18, 2006 2:31 am
- Location: In a galaxy, far, far away
- Contact:
Re:HW Port adresses and paged memory
hey, dude! what are you trying to do, here ? paging I/O ports ?
ports are *not* memory locations. Despites many architecture (powerPC, sparcs, etc) uses memory-mapped IO, Intel processor have dedicated in <port>,a* and out <port>,a* instructions and I/O address space is totally distinct from memory address space (for instance, IO space is only 16 bits wide
So, whatever the memory mapping you set up with your pager, keyboard port will *always* be at 0x60.
ports are *not* memory locations. Despites many architecture (powerPC, sparcs, etc) uses memory-mapped IO, Intel processor have dedicated in <port>,a* and out <port>,a* instructions and I/O address space is totally distinct from memory address space (for instance, IO space is only 16 bits wide
So, whatever the memory mapping you set up with your pager, keyboard port will *always* be at 0x60.
-
- Member
- Posts: 1600
- Joined: Wed Oct 18, 2006 11:59 am
- Location: Vienna/Austria
- Contact:
Re:HW Port adresses and paged memory
Thanks for explanation gosh,
and NAY, I wouldna page hw-ports even in my weirdest dreams. I am not completely gone crazy *rofl*
I am spoiled by lowlevel hardware programming with microprocessors like pic16c74 (or similar) where you have to set input output masks to dedicated adresses in this small processors adress space prior to using them as input/output ports.
But that's what learning is good for. So I don't need to care about io-ports whilst using paging. this makes me happy
stay safe and thank ya, pype.
and NAY, I wouldna page hw-ports even in my weirdest dreams. I am not completely gone crazy *rofl*
I am spoiled by lowlevel hardware programming with microprocessors like pic16c74 (or similar) where you have to set input output masks to dedicated adresses in this small processors adress space prior to using them as input/output ports.
But that's what learning is good for. So I don't need to care about io-ports whilst using paging. this makes me happy
stay safe and thank ya, pype.
... the osdever formerly known as beyond infinity ...
BlueillusionOS iso image
BlueillusionOS iso image