* Sega AIME I/O, Bandai Namco I/O and Spicetools CardIO emulation.
* Command line for configurations.
* Supported card:
* FeliCa (Amusement IC)
* ISO/IEC 14443 Type A (BanaPassport, Mifare, Amiibo, some IC tags, some ID tags, etc.)
* ISO/IEC 15693 (Old E-Amusement cards), only with PN5180 (see notes 2 below)
* Emulates virtual AIC from any Mifare cards.
* All source files open.
**Notes:**
1. So one can integrate "AIC Pico" into other Raspberry Pi Pico based projects. See my Chu Pico project and see how it works.
<imgsrc="doc/aic_pico_lib.jpg"width="25%">
2. PN532 supports only 14443A (Mifare) and FeliCa cards, while PN5180 also supports 15693 cards (old e-Amusement cards).
## Thanks
Thanks to many respectful guys/companies who made their tools or materials free or open source (KiCad, OnShape, InkScape, Fritzing, Raspberry things), ChatGPT and GitHub Copilot helped a lot as well.
And thanks to community developers and projects that helped me a lot:
* CrazyRedMachine (https://github.com/CrazyRedMachine) for the Spicetools Card IO part;
* Sucareto's AIME Reader (https://github.com/Sucareto/Arduino-Aime-Reader) for the AIME protocol part;
* Bottersnike (https://gitea.tendokyu.moe/Bottersnike, https://sega.bsnk.me/) for AIME and FeliCa knowledge;
* .NET nanoFramework (https://github.com/nanoframework) for the PN5180 part;
* Gyt4 (https://github.com/gyt4/) for Bandai Namco card reader I/O;
* Bananatools (https://gitea.tendokyu.moe/Hay1tsme/bananatools) for Bandai Namco card reader I/O;
* chujohiroto (https://github.com/chujohiroto/Raspberry-RCS620S/blob/master/rcs620s.py), as indirect reference for the Bandai Namco card reader I/O;
## Warning
This project:
* Heavily depends on 3D printing, a Bambu AMS system helps a lot.
* Requires skills to solder tiny components and wires.
I made this project in my personal time with no financial benefit or sponsorship. I will continue to improve the project. I have done my best to ensure that everything is accurate and functional, there's always a chance that mistakes may occur. I cannot be held responsible for any loss of your time or money that may result from using this open source project. Thank you for your understanding.
Check out my other projects at my GitHub homepage.
https://github.com/whowechina/
## About the License
It's CC-NC. So DIY for yourself and for your friend, don't make money from it.
## Building "AIC Pico (PN532)"
Seriously, this is the easiest one among all my Pico series projects.
### Components
* 1x Rasberry Pi Pico or Pico W (clones work too).
* The firmware supports up to 64 LEDs on the WS2812B LED strip. I personally used 3 as shown in main title image. But you can have different LED number, as long as they fit within the housing.
* LED might be excessively bright even at low settings, consider covering it with some filter tape.
* The mode switch on PN532 must be in "I2C" mode, picture below shows the correct settings.
<imgsrc="doc/pn532_i2c.jpg"width="40%">
## Building "AIC Pico (PN5180)"
If you opt for the PN5180 NFC module, note that the housing design is up to you. Ensure it fits your design or you can use it without a case. Be prepared to solder more wires compared to the PN532 version.
### Wiring
<imgsrc="doc/pico_pn5180_wiring.png"width="70%">
Note: WS2812B LED Strip wiring is the same as the PN532 version.
## Building "AIC Key"
AIC Key is a variation of the AIC Pico - a keypad is integrated. Much more difficult to build than the "AIC Pico" as it has many tiny components to solder.
### Components
* 1x Rasberry Pi Pico or Pico W (clones work too).
* 1x Right angle 2.54mm pitch header, 4P for PN532, 13P for PN5180.
<imgsrc="doc/right_angle_header.jpg"width="20%">
* 1x Stickers of numbers. You can find some customize sticker service, or you can find some existing stickers. I found this Bonito crystal 3D stickers super helpful for this project.
<imgsrc="doc/bonito_stickers.png"width="50%">
<imgsrc="doc/bonito_action.jpg"width="50%">
* PCB, just visit JLCPCB (https://jlcpcb.com/) and place an order there. Leave everything default, 1.6mm thickness, whatever color you like. PCB gerber files are in "Production/PCB" folder. For PN532 version, use "aic_key_pn532_v*.zip", for PN5180 version, use "aic_key_pn5180_v*.zip".
<imgsrc="doc/pcbs.jpg"width="60%">
### 3D Prints
* **aic_key_bottom.stl**
Bottom part.
* **aic_key_top_surface.stl**
Top part for Alps surface switches.
* **aic_key_top_surface_ams.3mf**
Top part for Alps surface switches, multi-color printing.
* **aic_key_top_tact.stl.stl**
Top part for Panasonic tact switches.
* **aic_key_top_tact_ams.3mf**
Top part for Panasonic tact switches, multi-color printing.
### Assembly
Again I'll let these images do the talk. Remember to upload the firmware onto Raspberry Pi Pico before assemble.
#### General Part
<imgsrc="doc/key_assemble_1a.jpg"width="30%">
<imgsrc="doc/key_assemble_1b.jpg"width="30%">
<imgsrc="doc/key_assemble_2.jpg"width="30%">
#### PN532 Version
Remember set to I2C mode first.
<imgsrc="doc/pn532_i2c.jpg"width="40%">
<imgsrc="doc/key_assemble_3.jpg"width="80%">
<imgsrc="doc/key_assemble_4.jpg"width="40%">
<imgsrc="doc/key_assemble_5.jpg"width="40%">
#### PN5180 Version
You need to cut off the original antenna and use the one in our PCB.
<imgsrc="doc/key_assemble_6.jpg"width="40%">
<imgsrc="doc/key_assemble_7.jpg"width="40%">
<imgsrc="doc/key_assemble_8.jpg"width="40%">
<imgsrc="doc/key_assemble_9.jpg"width="40%">
#### Final Assembly
You may use some instant adhesive to fix stickers.
<imgsrc="doc/key_assemble_10.jpg"width="46%">
<imgsrc="doc/pico_assemble_4.jpg"width="40%">
## Firmware
* UF2 file is in `Production\Firmware` folder.
* There're several ways to boot into firmware update mode:
* For the new build, hold the BOOTSEL button while connect the USB to a PC, there will be a disk named "RPI-RP2" showed up. Drag the UF2 firmware binary file into it. That's it.
* If there's already a working firmware, you can use "update" command in command line to update the firmware in the future, so you don't need to open the housing.
* If there's already a working firmware later than 2023-12-02, you can also press "00" key and "·" key (or directly ground the GPIO10 and the GPIO11) at the same time when plug in the USB cable, it will boot into firmware update mode.
* You can use this Web Serial Terminal to connect to the main USB serial port of the board which is the command line interface. (Note: "?" is for help)