Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add remote control of the core and menu (via UART and/or Ethernet) #41

Open
MJoergen opened this issue Mar 18, 2024 · 4 comments
Open
Assignees
Labels
enhancement New feature or request research

Comments

@MJoergen
Copy link
Collaborator

MJoergen commented Mar 18, 2024

The use case is to be able to control the core and menu without needing physical access to the MEGA65. This could either be done over the serial (UART) port or over Ethernet.

This feature can be implemented in several stages of progressing usability and complexity.

  1. The first stage is to forward serial input to the core's and/or M2M's keyboard input.
  2. The second stage is to copy the OnScreen Menu frame buffer to the serial output (as text only).
  3. The video output from the core could be compressed and sent over the Ethernet, one frame at a time per request. In other words, the user types a keyboard sequence to force a screenshot (snapshot) of the current output frame. The protocol/format would be something proprietary, but easy to implement in the FPGA. This would be decompressed and converted to an image on the host computer.
    Note: I already have a proof-of-concept developed for another project on the Nexys4DDR board (https://github.com/MJoergen/nexys4ddr/tree/master/c64).
  4. This stage would continuously generate a stream of data sent over the Ethernet port. This would be converted to a video file, to be viewed later (not real time).
  5. The final stage would implement protocol support for some kind of Remote Desktop, that can connect to a standard client on the host machine. This requires a complete IP stack with TCP and UDP support

I expect stages 1-4 to be do-able with very modest resource requirements in the FPGA, and also modest development resources, given that there is already a working POC.
Stage 5 is much more complex: TCP is usually implemented in software, not hardware, so this will likely involve the QNICE CPU, perhaps only after interrupt support and/or DMA support is implemented.

@MJoergen MJoergen added enhancement New feature or request research labels Mar 18, 2024
@MJoergen MJoergen self-assigned this Mar 18, 2024
@MJoergen MJoergen changed the title Add remote control of the core (via UART and/or Ethernet) Add remote control of the core and menu (via UART and/or Ethernet) Mar 18, 2024
@gurcei
Copy link

gurcei commented Mar 27, 2024

This does sound cool in the sense of remote controlling menus and remote desktopping in, though part of me wonders about the ability to step debug issues on the c64 via a uart monitor too. If it is of a similar nature (same commands) to the mega65's uart monitor, then it could mean we could make use of existing tooling like m65dbg too. But anyways, I won't get in the way of your immediate plans if the more exciting goal is the remote control/desktop experience 🙂

@gurcei
Copy link

gurcei commented Mar 27, 2024

Some additional thoughts on existing uart monitor implementation within mega65-core in this discord thread:

https://discord.com/channels/719326990221574164/1222391068453244959/1222618515593494712

MJoergen added a commit that referenced this issue Nov 15, 2024
This is part 1 of issue #41

To enable the UART, set the constant ENABLE_UART to true in
CORE/vhdl/globals.vhd
@MJoergen
Copy link
Collaborator Author

MJoergen commented Nov 15, 2024

Part 1 is now implemented in commit e21f3e5.

The feature is default disabled and uses no extra resources in this configuration.

To enable the UART, set the constant ENABLE_UART to true in CORE/vhdl/globals.vhd.

The keyboard mapping is the same as for the XEMU:
https://github.com/MEGA65/mega65-user-guide/blob/master/images/xemu-extended-keyboard.png

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request research
Projects
None yet
Development

No branches or pull requests

2 participants