You are reading a single comment by @DrAzzy and its replies. Click here to read the full conversation.
  • Say you want to save memory storing functions (particularly verbose ones). I plan to do this for answering HTTP requests, since that's something that can involve a considerable amount of difficult-to-shrink code (the strings that need to be returned, mostly), yet is something that likely is not used all that often, so it can afford to drag a little bit.

    Let's start by adding this function to our eeprom object:

    1. I2C1.setup({scl:B8,sda:B9});
    2. rom=require("AT24").connect(I2C1,128,512);
    3. rom.r = function (id) {
    4. var x=this.read(1024+id*4,4);
    5. if (x[2]!=255) {return eval(this.reads((x[1]+(x[0]<<8)),(x[3]+(x[2]<<8))));}
    6. };

    Here, starting at 0x0400, we'll start storing a table of indices for functions stored on the eeprom, 4 bytes per (2 each for starting address, and length). We'll need some helper functions to load the EEPROM, and see what's on it. Setting all 4 bytes of the index entry for a function marks that function ID as unused, though we look at the third byte, because if that's 255, the result is unambiguously invalid.

    1. maxid=255;
    2. ftst=1024;
    3. //getList() returns an object containing one property for each function listed in the function index on the rom, and also prints out it's progress in human readable format to assist the operator in loading the rom.
    4. function getList() {
    5. var count=0;
    6. var map={};
    7. for (var i=0;i<maxid;i++) {
    8. var b=rom.read(ftst+i*4,4);
    9. if (b[2]!=255) { //if b[2]==255, length ~= 64K, which is clearly not valid data.
    10. count++;
    11. var a=b[1]+(b[0]<<8);
    12. var l=b[3]+(b[2]<<8);
    13. map[i]=[a,l];
    14. console.log(i+". 0x"+a.toString(16)+" "+l+" bytes.");
    15. }
    16. }
    17. console.log("Scan complete "+ count+ " functions in index");
    18. return map;
    19. }
    20. //getFunction(id) will return a string containing the code for that function, assuming it exists.
    21. function getFunction(id) {
    22. var x=rom.read(ftst+id*4,4);
    23. if (x[2]!=255) {return rom.reads((x[1]+(x[0]<<8)),(x[3]+(x[2]<<8)));}
    24. }
    25. //isSafe(address, length, map) takes a 'map' object (as returned by getList()), and returns 1 if a function of specified length can be placed in the specified address without overwriting something.
    26. //If it fails, print the ID of the function that it's got a problem with.
    27. function isSafe(adr,len,map) {
    28. var max=len+adr;
    29. for (var i=0;i<maxid;i++) {
    30. if (map[i]!=undefined) {
    31. var a=map[i][0];
    32. var l=map[i][1];
    33. if (((a < adr)&&(a+l > adr))||((a > adr)&&(a < max))) {
    34. console.log("Conflict on function "+i);
    35. return 0;
    36. }
    37. }
    38. }
    39. return 1;
    40. }
    41. //addFunction(id, address, function) - This creates a new entry for a function of 'id', located at 'address' in the function index, and writes that and the function (supplied as a string) to the rom, provided that that can be done without overwriting another function.
    42. function addFunction(id,adr,str) {
    43. console.log("Adding function of length "+str.length+" at address "+adr+" with ID: "+id);
    44. if (isSafe(adr,str.length,getList())) {
    45. rom.writel(adr,str);
    46. var tarr=new Uint8Array(4);
    47. tarr[0]=(adr>>8);
    48. tarr[1]=(adr&0xFF);
    49. tarr[2]=(str.length>>8);
    50. tarr[3]=(str.length&0xFF);
    51. rom.writeb(ftst+4*id,tarr);
    52. } else {
    53. console.log("Selected location would overlap with other function!");
    54. }
    55. }
    56. //deleteFunction(id) deletes the function with that ID from the function index.
    57. function deleteFunction(id) {
    58. console.log("deleting function: " + id);
    59. rom.writes(ftst+4*id,"\xFF\xFF\xFF\xFF");
    60. }
    61. //cleanup - remove all the stuff related to this.
    62. function cleanup() {
    63. delete getFunction;
    64. delete isSafe;
    65. delete deleteFunction;
    66. delete getList;
    67. delete addFunction;
    68. delete maxid;
    69. delete getFunction;
    70. delete ftst;
    71. delete cleanup;
    72. }

    And of course, the first function we add can be this one:

    1. addFunction(0,2048,'ftst=1024;maxid=255;function getList(){for(var a=0,d={},c=0;c<maxid;c++){var b=rom.read(ftst+4*c,4);if(255!=b[2]){a++;var e=b[1]+(b[0]<<8),b=b[3]+(b[2]<<8);d[c]=[e,b];console.log(c+". 0x"+e.toString(16)+" "+b+" bytes.")}}console.log(a+" functions in index");return d}function getFunction(a){a=rom.read(ftst+4*a,4);if (a[2]!=255) {return rom.reads(a[1]+(a[0]<<8),a[3]+(a[2]<<8))}function isSafe(a,d,c){d+=a;for(var b=0;b<maxid;b++)if(void 0!=c[b]){var e=c[b][0],f=c[b][1];if(e<a&&e+f>a||e>a&&e<d)return console.log("Conflict on function "+b),0}return 1}function addFunction(a,d,c){console.log("Add fun of length "+c.length+" @ "+d.toString(16)+" ID: "+a);if(isSafe(d,c.length,getList())){rom.writel(d,c);var b=new Uint8Array(4);b[0]=d>>8;b[1]=d&255;b[2]=c.length>>8;b[3]=c.length&255;rom.writeb(ftst+4*a,b)}else console.log("Not enough space there!")}function deleteFunction(a){console.log("deleting function: "+a);rom.writes(ftst+4*a,"\xff\xff\xff\xff")} function cleanup() {delete getFunction;delete isSafe;delete deleteFunction;delete getList;delete addFunction;delete maxid;delete getFunction;delete ftst;delete cleanup;}');

    Length is like 1160 bytes.

About

Avatar for DrAzzy @DrAzzy started