64 CONTROLLER 64 CONTROLLER AARON RIDENOUR, RYAN WOOSTER, ALEX JAECKEL
CONTROLLER Inputs: A, B, L, R, Z, start, C-up C-down, C-left, C-right, D-Pad(up, down, left, right), Joystick Options: Rumble Pak, Memory Pak
ACTION BUTTONS Each buttons sits atop a metal plate. When the button is pressed, the metal plate contacts two strips of conductive material attached to the circuit board, creating a current. The controller senses this current, and sends a logical 1 if the button is pressed, and a logical 0 if the button is not pressed.
JOYSTICK Two wheels positioned at right angles to each other, one for the x-axis, one for the y-axis.
JOYSTICK Incremental Encoding Each wheel has slits around the perimeter Controller counts how many times the light sensors see the LED through the slits, and uses that to determine position. One wheel for each axis.
JOYSTICK The controller knows which way the joystick is moving by looking at which sensor sees the LED first.
CONNECTION TO N64 afermiano.com/index.php/n64-controller-protocol Vcc = 3.3V Data line is bidirectional A pull up-resistor is needed to read the line
OPEN COLLECTOR Pull-up resistor keeps the line high while idle. To send 0, the output line is pulled low and connected to ground. To send 1, nothing should be sent. Do not drive the line high.
OPEN COLLECTOR Sending a logical 0:
OPEN COLLECTOR Sending a logical 1:
CONTROLLER ENCODING Logical 0: Logical 1:
CONTROLLER ENCODING
COMMUNICATION PROTOCOL When a Command byte is sent to the controller, it sends a response depending on which command was sent. Check Controller Command: 0x00 The controller responds with 3 bytes. The first two bytes are always 0x0500 Last byte is determined by: 0x01: If a controller pack is connected. 0x02: If no controller pack is connected. 0x04: If a previous command resulted in an error.
Reset Controller Command: 0xFF First resets the controller, including resetting the joystick calibration Controller then responds as in the Check Controller Command COMMUNICATION PROTOCOL
Input Polling Command: 0x01 The controller responds with 4 bytes, encoding the button and joystick values The controller responds with 4 bytes, encoding the button and joystick values ByteData[7]Data[6]Data[5]Data[4]Data[3]Data[2]Data[1]Data[0] 1ABZStartD-UpD-DownD-LeftD-Right 2Joystick Reset 0LRC-UpC-DownC-LeftC-Right 3Signed joystick x-axis coordinate 4Signed joystick y-axis coordinate The joystick values range between -128 and 127, but the controller physically can only use from -81 to 81.
EXAMPLE DATA WAVEFORM |----Command (console) 0x ||----Data1 (controller) 0x00----||-----Data2 (controller) 0x00----| | Data3 (controller) 0x | | Data4 (controller) 0x | ABZ St reset 0 L R Joystick x-coordinateJoystick y-coordinate start bit stop bit Images taken from:
COMMUNICATION PROTOCOL Controller Pack Read: 0x02 Used to read from the controller pack. Used to read from the controller pack. The command is followed by 2 bytes which indicate the address being read from and a CRC to verify the address. The command is followed by 2 bytes which indicate the address being read from and a CRC to verify the address. The controller responds with 32 bytes of data from that address, followed by the data CRC. The controller responds with 32 bytes of data from that address, followed by the data CRC.
Controller Pack Write: 0x03 Used to write to the controller pack. Used to write to the controller pack. The command is followed by 2 bytes which indicate the address being written to, a CRC to verify the address and the 32 bytes of data to write. The command is followed by 2 bytes which indicate the address being written to, a CRC to verify the address and the 32 bytes of data to write. The controller responds with the data CRC. The controller responds with the data CRC. COMMUNICATION PROTOCOL
CRC: Used to verify that data was sent correctly. Used to verify that data was sent correctly. Outside scope of this presentation. Outside scope of this presentation.
RUMBLE PAK Use the 0x03 command. Use the 0x03 command. To initialize: To initialize: Send to address 0x8001. Send to address 0x8001. Send 0x80 (repeated 34 times) as the data. Send 0x80 (repeated 34 times) as the data. To run the Rumble Pak: To run the Rumble Pak: Send to address 0xc01b. Send 0x01 (repeated 32 times) as the data to start the Pak. Send 0x00 (repeated 32 times) as the data to stop the Pak.
REFERENCES m.inc m.inc