Commit Graph

150 Commits

Author SHA1 Message Date
Kartik K. Agaram
08c55cb2b7 7713 2021-02-10 22:34:08 -08:00
Kartik K. Agaram
2be221bce8 7712 2021-02-10 22:14:46 -08:00
Kartik K. Agaram
d4afe371f5 7711 - baremetal/shell: line data structure
Pretty thin; perhaps we should put cursor management in words. But we don't
need every node in the list of words to know which word in the list the
cursor is at.
2021-02-10 22:11:54 -08:00
Kartik K. Agaram
07852ae00f 7710
Include a file for commit 7708.
2021-02-10 20:08:32 -08:00
Kartik K. Agaram
4a3414791f 7709
Fix the jarringness in the previous commit. Gap buffers now always occupy
the same width on screen regardless of where their cursor is. The price:
we sometimes have more whitespace between words. But that is perhaps a
good thing.
2021-02-09 23:18:20 -08:00
Kartik K. Agaram
7d40021799 7708 - baremetal/shell: word data structure
Not everything here is tested, but enough that I'm starting to feel confident.

We see our first divergence with apps/tile. In apps/tile we render everything,
then go back and figure out where to position the cursor. This relies on
some low-level smarts and is also quite klunky and complex.

In baremetal/shell I plan to do something simpler: maintain a tree of objects
where each level knows which sub-object under it has the cursor. Now I
can pass in the cursor object to each object, and if it detects that it
has the cursor it can recursively figure out which sub-object has the cursor.
The bottom-most objects (grapheme stacks) draw the cursor as they render
themselves. Single-pass algorithm, draw the cursor as you render, no low-level
smarts needed.

But there's a divergence. What in apps/tile used to look like this, with
a cursor ␣ at the end of the word 'abc':

  abc␣def

..now looks like this:

  abc␣ def

..with an extra space.

This could cause some jarring 'dancing' as you move the cursor through a
list of words.
2021-02-09 22:57:37 -08:00
Kartik K. Agaram
1969febce5 7707 2021-02-09 22:00:02 -08:00
Kartik K. Agaram
f3f6bc3f01 7706 2021-02-09 21:57:11 -08:00
Kartik K. Agaram
dfa61e6299 7705 2021-02-09 21:53:24 -08:00
Kartik K. Agaram
c29e589b6a 7704 2021-02-09 21:42:44 -08:00
Kartik K. Agaram
d5011d5187 7703 2021-02-09 21:42:14 -08:00
Kartik K. Agaram
9a91f0a840 7702 2021-02-09 21:41:58 -08:00
Kartik K. Agaram
c1e841fc2d 7701 2021-02-09 20:53:47 -08:00
Kartik K. Agaram
168e3f9d39 7699
Gap buffer with a more testable interface for rendering to screen.
2021-02-08 22:20:21 -08:00
Kartik Agaram
bfcf5c7252 7698 - starting to test-drive baremetal shell 2021-02-07 23:45:31 -08:00
Kartik Agaram
0be63b75c2 7697 2021-02-07 22:42:33 -08:00
Kartik Agaram
899759edef 7696 2021-02-07 22:24:27 -08:00
Kartik Agaram
a99775b445 7695 - baremetal: second bg assertion for spaces
When I'm also checking graphemes I assume that spaces can be in other bg
colors. However, if I want to closely check the bg color for a cell with
a space in it (ahem, cursor), I have to check the color in isolation.
2021-02-07 21:12:11 -08:00
Kartik Agaram
1d7aae96f0 7694 - baremetal: asserting bg color in tests 2021-02-07 20:51:54 -08:00
Kartik Agaram
8f34dfd1e0 7693 - baremetal: pass background color everywhere 2021-02-07 15:50:16 -08:00
Kartik Agaram
74f1512ff1 7690
Convert comments about magic constants into metadata.
2021-02-07 00:20:29 -08:00
Kartik Agaram
f0ef1ca231 7687 2021-02-05 20:35:23 -08:00
Kartik Agaram
c6b8df9d72 7686 2021-02-04 17:25:00 -08:00
Kartik Agaram
022ecb94f0 7684 - baremetal will have no mouse
I spent a week on trying to support it, and I am now past the five
stages of grief.

-- Important things I read
https://web.archive.org/web/20040604041507/http://panda.cs.ndsu.nodak.edu/~achapwes/PICmicro/keyboard/atkeyboard.html
https://web.archive.org/web/20040604043149/http://panda.cs.ndsu.nodak.edu/~achapwes/PICmicro/mouse/mouse.html

https://wiki.osdev.org/index.php?title=Mouse_Input&oldid=23086#Waiting_to_Send_Bytes_to_Port_0x60_and_0x64
  says command 0xa8 is optional

SaniK: https://forum.osdev.org/viewtopic.php?t=10247
  recommends command 0xa8 before setting Compaq Status byte

Setting Compaq status byte before 0xa8: https://forum.osdev.org/viewtopic.php?f=1&t=19873
  This thread also suggests that keeping reads from keyboard vs mouse straight
  is non-trivial.

-- Where I got stuck
Following SaniK's recipe doesn't seem to work. It seems like not sending
the 0xa8 command gets us a little closer. I saw the mouse handler
trigger, but it seems to not actually happen in response to mouse
events (vector 0x74 in the interrupt descriptor table).

-- Other options that may be worth considering
USB mouse
Serial mouse

Implementing a PS/2 handler in SubX
  would require somehow referring to SubX labels in this file

It seems clear that a mouse driver is complex enough to need a
higher-level language than just hex bytes. But it's _not_ clear how to
_explain_ a mouse driver. There's just a lot of random rules, historical
anecdotes, just-so stories and sheer black magic here. I'm going to try
to do without it all. Mu will be a keyboard-only computer for the
foreseeable future.
2021-02-03 09:49:40 -08:00
Kartik Agaram
7212178bc6 7683 2021-02-01 22:56:50 -08:00
Kartik Agaram
cd83a22a59 7682 2021-02-01 13:26:48 -08:00
Kartik Agaram
2a9583414b 7679 - baremetal: delete mouse handler
What I have so far is crap. Roll baremetal/boot.hex back to commit 7673.
2021-01-31 21:03:59 -08:00
Kartik Agaram
d66bf07b44 7678 2021-01-30 23:41:11 -08:00
Kartik Agaram
78d3df417a 7676 2021-01-30 23:38:39 -08:00
Kartik Agaram
9e315ddf40 7674 - beginning of mouse driver
No handler yet, just initialization.

Bochs boots up; Qemu gets into a reboot loop.

Unlike the keyboard where I did the minimum necessary for Qemu, here I
am blindly copying something alleged to work on "real hardware." Makes
no difference to the failure modes I'm seeing.

Even in this tiny endeavor I see the abyss open up. Poke bytes at some
sequence of ports, read back bytes from some sequence ports; it's like
sending out prayers.
2021-01-28 00:39:50 -08:00
Kartik Agaram
fa0e67c172 7673 2021-01-28 00:25:54 -08:00
Kartik Agaram
49badfb697 7672 2021-01-27 21:52:44 -08:00
Kartik Agaram
ca5ac5154e 7671
Make some room for a mouse handler.
2021-01-27 21:16:36 -08:00
Kartik Agaram
2c2ba73f65 7670 2021-01-27 21:09:45 -08:00
Kartik Agaram
9ebc8ad439 7569 2021-01-27 20:53:50 -08:00
Kartik Agaram
c98476aa09 7568 2021-01-27 20:24:41 -08:00
Kartik Agaram
bcb656a7e8 7567 - baremetal: shift-key support 2021-01-27 19:54:05 -08:00
Kartik Agaram
4c9587b5f4 7566 2021-01-27 16:51:23 -08:00
Kartik Agaram
212d72a2df 7565
Somehow everything worked with this bug.
2021-01-24 22:44:43 -08:00
Kartik Agaram
0373ace5e0 7564 2021-01-24 22:25:10 -08:00
Kartik Agaram
5d5b9b2e9b 7563
Yup, a single read suffices. Might not work on real hardware, but YAGNI.
2021-01-24 22:19:43 -08:00
Kartik Agaram
d5ed008900 7562 - bochs working again
Holy crap, perhaps the limitations of int 13h were all a mirage. I just
needed to initialize the stack.
2021-01-24 22:00:53 -08:00
Kartik Agaram
4559206243 7561
Another attempt at reorganizing how I read disks. Everything continues
to work in Qemu, but Bochs still doesn't love me.
2021-01-24 21:24:35 -08:00
Kartik Agaram
ec75fe7f28 7560 2021-01-24 20:54:53 -08:00
Kartik Agaram
3844651e49 7559 - reorganize sectors built in raw hex
This was tedious for three reasons beyond the usual one of having to
track and update offsets several time while I debug:
  - The Bochs troubles of the previous commit kept polluting my brain
    even though they were irrelevant.
  - I had to keep some changes locally to allow myself to use Bochs,
    which polluted my working directory.
  - I had to travel the long way to the realization that I'm not
    actually initializing the stack anywhere. BIOS was starting my stack
    off at 0x10000, which was promptly clobbered by my second read from
    disk.

The good news: while I'm here I grow the interrupt descriptor table. So
I don't have to go through this exercise when I get back to supporting
the mouse.
2021-01-24 20:16:27 -08:00
Kartik Agaram
1c77be68d7 7558
Bochs is still broken, but before we can fix it we need to make some
room in the boot sector. So we'll spend a few commits reorganizing
things.
2021-01-24 19:43:23 -08:00
Kartik Agaram
0cf7cecedc 7557
Oh, stupid mistake in segmented address calculation. Now Qemu's working
again everywhere. Bochs is again broken everywhere. But I think we're
getting closer. I think Bochs's BIOS implementation for reading sectors
has two interacting constraints:

  - Can't write to more than 0x10000 bytes past segment register.
  - Can't write across segment alignment boundaries.

Qemu only cares about the first.
2021-01-24 19:43:23 -08:00
Kartik Agaram
09f2f3075a 7555 - snapshot
While baremetal has been working with Qemu, it's been broken with Bochs
since commit 7547, where we started reading more than 63 sectors (1
track) from disk.

Good to know that Bochs simulates native hardware with so much
verisimilitude!

Unfortunately things aren't fixed yet. The current state:

             - Qemu -                 - Bochs -
  ex2.hex    never switches modes     works
  ex2.subx   never switches modes     works
  ex2.mu     never switches modes     fails unit tests

It sucks that Bochs doesn't have strictly superior verisimilitude
compared to Qemu :(
2021-01-24 19:43:23 -08:00
Kartik Agaram
dba18f7f6f 7554 - bug in an error handler 2021-01-24 19:43:23 -08:00
Kartik Agaram
0e4e8355f0 7553 2021-01-24 19:43:23 -08:00