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

More Tube ULA fun #398

Open
samskivington-poq opened this issue Aug 15, 2023 · 2 comments
Open

More Tube ULA fun #398

samskivington-poq opened this issue Aug 15, 2023 · 2 comments

Comments

@samskivington-poq
Copy link
Contributor

samskivington-poq commented Aug 15, 2023

Hello.

I know you've said you're not completely familiar with the Tube in the previous issue I raised, but Is there a reason why jsBeeb's implementation forces me to write code that introduces a delay between repeatedly polling the ULA to know when the R1 FIFO has space and then writing to it, and doing the same again, whereas on a real machine that is not required? It's slowing my parasite code down unnecessarily in jsBeeb, for something that needs to run as fast as possible.

The result of running the code in the .else block is that spurious values are received on the host side of R1 that are nothing to do with the actual values written on the parasite side, at a rate of roughly 500ms. Hoping the 500ms points you to the cause.

In this instance, the parasite OS and Acorn host code have both been completely eliminated and this is raw, tight loop communication between both sides. This code snippet is run as part of a NMI handler on the parasite side.

	;	write the command queue
_loopCommandQueue
	lda	ZP_COMMAND_QUEUE_INPUT_PTR
	cmp	ZP_COMMAND_QUEUE_OUTPUT_PTR
	bne	_doCommandQueueByte
	lda	ZP_COMMAND_QUEUE_INPUT_PTR + 1
	cmp	ZP_COMMAND_QUEUE_OUTPUT_PTR + 1
	beq	_done

_doCommandQueueByte
	lda	(ZP_COMMAND_QUEUE_OUTPUT_PTR)

.ifdef JSBEEB_BROKEN_TUBE
	;	RAISE-ISSUE: Tube ULA timing
	;	the code in the .else block waits until there is space in the FIFO
	;	and is the exact same code as in the function TubeParasiteWriteR1
	;	I shouldn't need to introduce a delay like this
	;	I don't on a real machine or in BeebEm
	;	but I do in b-Em and jsBeeb
	;	this is parasite side and interrupts are enabled
	; 	but nothing is even attempting to trigger them at this point
	beq	_send
	cmp	#0
	bcs	_send
_send
	jsr	TubeParasiteWriteR1
.else

_loopWaitUntilR1HasSpace
	bit	TUBE_STATUS_REGISTER_1_PARASITE
	bvc	_loopWaitUntilR1HasSpace
	sta	TUBE_DATA_REGISTER_1_PARASITE

.endif

	inc	ZP_COMMAND_QUEUE_OUTPUT_PTR
	bne	_loopCommandQueue
	inc	ZP_COMMAND_QUEUE_OUTPUT_PTR + 1
	bne	_loopCommandQueue

_done

Thanks
Sam

@mattgodbolt
Copy link
Owner

Hi Sam! Honeslty, nothing in the Tube stuff is "on purpose" :) I copy pasted from various emulators until Tube Elite "sort of" worked. I can't imagine what's causing those 500ms pulses BUT I'll try and take a look.

Thanks for taking the time to file this!

@samskivington-poq
Copy link
Contributor Author

If it helps (could be random) the spurious values in my case were either 3 or 4, whereas I was only sending 1 or 0.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants