NicoHood / Nintendo

Use Nintendo Controllers with Arduino
http://www.nicohood.de
MIT License
278 stars 55 forks source link

N64 need a delay between begin() and read() #22

Closed Danjovic closed 3 years ago

Danjovic commented 5 years ago

I was always getting and error while running N64Controller.ino example. While troubleshooting the code I have found that if you went too fast between sending the initialization command (0x00) on begin() function to sending a request 0x01 on read() function the controller does not answer to the request. The standard example code takes 23us from end of answer to command 0x00 to begin of command 0x01. I have modified the example (see code below) and experimented some delay values and checked the output using a saleae logic analyzer.

void loop()
{
    N64Controller.begin();
    delayMicroseconds(100);  // Added delay
  // Try to read the controller data
  if (N64Controller.read())
  {
    // Print Controller information

with the added delay I still had issues while the total time was under 80us.

Then I suggest you to add such a delay right before returning on CN64Controller::begin(void) function or at least mention that issue in documentation.

NicoHood commented 4 years ago

Thanks for that suggestion! I try to fix it soon.

NicoHood commented 4 years ago

Sorry for the late reply.

I've checked the code, but it does not contain a begin() function at all. So Why did you add it? Is it even required? Or do you just need some delay inside the loop? What if you move the begin() to the end of the setup) function?

Danjovic commented 4 years ago

Hi The begin() method is inside the CN64Controller class (in N64API.h) . Such method is called implicitly by the read() method when the property 'Connected' is not true. My N64 controller refuses to answer without a short delay between the initialization (gc_init() ) and the first read (n64_read() ). I think the controller need that time to properly initialize itself. The loop() worked fine without much delay between consecutive readings. To make the library built-in example work I just added a call to .begin() method followed by a delayMicroseconds(100) on the arduino setup()

NicoHood commented 3 years ago

@JonnyHaystack Can you maybe help here? I guess you are currently more into the code than me...

JonnyHaystack commented 3 years ago

Not sure why this would be a problem sorry. I don't have a setup for testing with an N64 controller either

Skuzee commented 3 years ago

My N64 controller is not recognized/initialized without adding a delay after begin() is called. Specifically in file: N64API.hpp, in the read function, between lines 81&82

bool CN64Controller::read(void)
{
    // Check if the controller was initialized
    if (!connected())
    {
        // Try to init the controller
        if (!begin())
        {
            return false;
        }
    delayMicroseconds(100);
    }

(I would fork and edit it, but I already have my own version of this library and git gets confusing for me.)

NicoHood commented 3 years ago

Thank you guys! I've fixed the issue now. Please check that out.