Git Product home page Git Product logo

Comments (4)

feilipu avatar feilipu commented on June 2, 2024

Ok, so I changed the code to support 16bit pointers in an gcc-avr libc-avr environment for ATmega devices. Individual devices are addressed by the most significant Byte of the 4 Byte address. 24 bits remain for addressing within the SRAM / FRAM / EEPROM device.

Result can be found here. https://sourceforge.net/projects/avrfreertos/files/freeRTOS/lib_eefs/

goldilocksfram

from eefs.

 avatar commented on June 2, 2024

Nice work!
Sorry I could not help with the 16 bit pointers, we have only used the EEFS on 32 bit CPUs so far.
( I have the same FRAM board for my raspberry Pi.. I will have to try that )
Alan

from eefs.

feilipu avatar feilipu commented on June 2, 2024

Thanks Alan,

I need to do some more testing and prove I've not broken your code, and then I'll create a "16 bit pointer" fork for you.

The background is that I'm building an Arduino derivative board using an ATmega1284p with two SRAM / FRAM / EEPROM SPI slots. The intent is to use these devices to feed the dual channel MCP4822 DAC. The largest 5V SPI RAM device seems to be only 1Mbit and so 17 address bits are needed. That means I could use the high address byte (of 32 bits) to address each device.
http://feilipu.me/2014/12/06/goldilocks-analogue-part-6/

I've built a tool to take the geneepromfs output file from a FatFS uSD card, and then write it to the (S/F)RAM at any Base Address.

The footprint of the two SPI (S/F)RAM devices can be seen next to the MCU. FRAM devices are only 8kByte at 5V, and that is not many samples. So, I'll probably use SRAM or EEPROM in practice, as they're available in 128kByte versions.
goldilocksanalogue_alllayers

from eefs.

feilipu avatar feilipu commented on June 2, 2024

Finally finished the testing, and adjusted the AVR ATmega code to reduce the overhead from returning 32 bit error values.

Made no changes to the on FRAM/SRAM/EEPROM file structure so the standard FRAM image generating tools will work as expected.

https://github.com/feilipu/eefs

Note that this fork uses some elements from freeRTOS for semaphore locks etc.
The hardware interface is the AVR ATmega SPI bus.

from eefs.

Related Issues (4)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.