| Index: emcore/trunk/tools/emcore.py | 
| — | — | @@ -85,7 +85,7 @@ | 
| 86 | 86 | logger.write(doc[function]['documentation']+"\n", 4) | 
| 87 | 87 | logger.write("\n") | 
| 88 | 88 | logger.write("\n") | 
| 89 |  | -
 | 
|  | 89 | + | 
| 90 | 90 | if errormsg: | 
| 91 | 91 | logger.error(str(errormsg)+"\n") | 
| 92 | 92 | exit(2) | 
| — | — | @@ -134,7 +134,7 @@ | 
| 135 | 135 | self.logger.error("No emCORE device found!\n") | 
| 136 | 136 | exit(1) | 
| 137 | 137 | self.getinfo("version") | 
| 138 |  | -        
 | 
|  | 138 | + | 
| 139 | 139 | def _parsecommand(self, func, args): | 
| 140 | 140 | # adds self to the commandline args. | 
| 141 | 141 | # this is needed because the functions need access to their class. | 
| — | — | @@ -182,7 +182,7 @@ | 
| 183 | 183 | elif something.lower() in falselist: | 
| 184 | 184 | return False | 
| 185 | 185 | raise ArgumentTypeError("bool", "'%s'" % something) | 
| 186 |  | -
 | 
|  | 186 | + | 
| 187 | 187 | @staticmethod | 
| 188 | 188 | def _hexint(something): | 
| 189 | 189 | """ | 
| — | — | @@ -309,7 +309,7 @@ | 
| 310 | 310 | f.write(self.emcore.read(addr, size)) | 
| 311 | 311 | f.close() | 
| 312 | 312 | self.logger.info("done\n") | 
| 313 |  | -
 | 
|  | 313 | + | 
| 314 | 314 | @command | 
| 315 | 315 | def uploadint(self, addr, integer): | 
| 316 | 316 | """ | 
| — | — | @@ -324,7 +324,7 @@ | 
| 325 | 325 | data = struct.pack("I", integer) | 
| 326 | 326 | self.emcore.write(addr, data) | 
| 327 | 327 | self.logger.info("Integer '0x%X' written successfully to 0x%X\n" % (integer, addr)) | 
| 328 |  | -
 | 
|  | 328 | + | 
| 329 | 329 | @command | 
| 330 | 330 | def downloadint(self, addr): | 
| 331 | 331 | """ | 
| — | — | @@ -335,7 +335,7 @@ | 
| 336 | 336 | data = self.emcore.read(addr, 4) | 
| 337 | 337 | integer = struct.unpack("I", data)[0] | 
| 338 | 338 | self.logger.info("Read '0x%X' from address 0x%X\n" % (integer, addr)) | 
| 339 |  | -
 | 
|  | 339 | + | 
| 340 | 340 | @command | 
| 341 | 341 | def i2cread(self, bus, slave, addr, size): | 
| 342 | 342 | """ | 
| — | — | @@ -354,7 +354,7 @@ | 
| 355 | 355 | self.logger.info("Data read from I2C:\n") | 
| 356 | 356 | for index, byte in enumerate(bytes): | 
| 357 | 357 | self.logger.info("%02X: %02X\n" % (index, byte)) | 
| 358 |  | -
 | 
|  | 358 | + | 
| 359 | 359 | @command | 
| 360 | 360 | def i2cwrite(self, bus, slave, addr, *args): | 
| 361 | 361 | """ | 
| — | — | @@ -374,7 +374,7 @@ | 
| 375 | 375 | self.logger.info("Writing data to I2C...\n") | 
| 376 | 376 | self.emcore.i2cwrite(bus, slave, addr, data) | 
| 377 | 377 | self.logger.info("done\n") | 
| 378 |  | -
 | 
|  | 378 | + | 
| 379 | 379 | @command | 
| 380 | 380 | def console(self): | 
| 381 | 381 | """ | 
| — | — | @@ -384,7 +384,7 @@ | 
| 385 | 385 | resp = self.emcore.usbcread() | 
| 386 | 386 | self.logger.write(resp.data) | 
| 387 | 387 | time.sleep(0.1 / resp.maxsize * (resp.maxsize - len(resp.data))) | 
| 388 |  | -
 | 
|  | 388 | + | 
| 389 | 389 | @command | 
| 390 | 390 | def writeusbconsole(self, *args): | 
| 391 | 391 | """ | 
| — | — | @@ -396,7 +396,7 @@ | 
| 397 | 397 | text = text[:-1] | 
| 398 | 398 | self.logger.info("Writing '%s' to the usb console\n" % text) | 
| 399 | 399 | self.emcore.usbcwrite(text) | 
| 400 |  | -
 | 
|  | 400 | + | 
| 401 | 401 | @command | 
| 402 | 402 | def readdevconsole(self, bitmask): | 
| 403 | 403 | """ | 
| — | — | @@ -422,7 +422,7 @@ | 
| 423 | 423 | text = text[:-1] | 
| 424 | 424 | self.logger.info("Writing '%s' to the device consoles identified with 0x%X\n" % (text, bitmask)) | 
| 425 | 425 | self.emcore.cwrite(text, bitmask) | 
| 426 |  | -
 | 
|  | 426 | + | 
| 427 | 427 | @command | 
| 428 | 428 | def flushconsolebuffers(self, bitmask): | 
| 429 | 429 | """ | 
| — | — | @@ -432,7 +432,7 @@ | 
| 433 | 433 | bitmask = self._hexint(bitmask) | 
| 434 | 434 | self.logger.info("Flushing consoles identified with the bitmask 0x%X\n" % bitmask) | 
| 435 | 435 | self.emcore.cflush(bitmask) | 
| 436 |  | -
 | 
|  | 436 | + | 
| 437 | 437 | @command | 
| 438 | 438 | def getprocinfo(self): | 
| 439 | 439 | """ | 
| — | — | @@ -497,7 +497,7 @@ | 
| 498 | 498 | threadaddr = self._hexint(threadaddr) | 
| 499 | 499 | self.logger.info("Suspending the thread with the threadaddr 0x%X\n" % threadaddr) | 
| 500 | 500 | self.emcore.suspendthread(threadaddr) | 
| 501 |  | -
 | 
|  | 501 | + | 
| 502 | 502 | @command | 
| 503 | 503 | def resumethread(self, threadaddr): | 
| 504 | 504 | """ | 
| — | — | @@ -506,7 +506,7 @@ | 
| 507 | 507 | threadaddr = self._hexint(threadaddr) | 
| 508 | 508 | self.logger.info("Resuming the thread with the threadaddr 0x%X\n" % threadaddr) | 
| 509 | 509 | self.emcore.resumethread(threadaddr) | 
| 510 |  | -
 | 
|  | 510 | + | 
| 511 | 511 | @command | 
| 512 | 512 | def killthread(self, threadaddr): | 
| 513 | 513 | """ | 
| — | — | @@ -515,7 +515,7 @@ | 
| 516 | 516 | threadaddr = self._hexint(threadaddr) | 
| 517 | 517 | self.logger.info("Killing the thread with the threadaddr 0x%X\n" % threadaddr) | 
| 518 | 518 | self.emcore.killthread(threadaddr) | 
| 519 |  | -
 | 
|  | 519 | + | 
| 520 | 520 | @command | 
| 521 | 521 | def createthread(self, nameptr, entrypoint, stackptr, stacksize, threadtype, priority, state): | 
| 522 | 522 | """ | 
| — | — | @@ -552,7 +552,7 @@ | 
| 553 | 553 | with f: | 
| 554 | 554 | data = self.emcore.run(f.read()) | 
| 555 | 555 | self.logger.info("Executed emCORE application as thread 0x%X\n" % data.thread) | 
| 556 |  | -
 | 
|  | 556 | + | 
| 557 | 557 | @command | 
| 558 | 558 | def execimage(self, addr): | 
| 559 | 559 | """ | 
| — | — | @@ -674,7 +674,7 @@ | 
| 675 | 675 | data = self.emcore.read(destination, sha1size) | 
| 676 | 676 | hash = ord(data) | 
| 677 | 677 | self.logger.info("The generated hash is 0x%X\n" % hash) | 
| 678 |  | -
 | 
|  | 678 | + | 
| 679 | 679 | @command | 
| 680 | 680 | def ipodnano2g_getnandinfo(self): | 
| 681 | 681 | """ | 
| — | — | @@ -687,7 +687,7 @@ | 
| 688 | 688 | self.logger.info("Number of blocks: %d\n" % data["blocks"]) | 
| 689 | 689 | self.logger.info("Number of user blocks: %d\n" % data["userblocks"]) | 
| 690 | 690 | self.logger.info("Pages per block: %d\n" % data["pagesperblock"]) | 
| 691 |  | -
 | 
|  | 691 | + | 
| 692 | 692 | @command | 
| 693 | 693 | def ipodnano2g_nandread(self, addr, start, count, doecc=True, checkempty=True): | 
| 694 | 694 | """ | 
| — | — | @@ -708,7 +708,7 @@ | 
| 709 | 709 | (count, start, addr)) | 
| 710 | 710 | self.emcore.ipodnano2g_nandread(addr, start, count, doecc, checkempty) | 
| 711 | 711 | self.logger.info("done\n") | 
| 712 |  | -
 | 
|  | 712 | + | 
| 713 | 713 | @command | 
| 714 | 714 | def ipodnano2g_nandwrite(self, addr, start, count, doecc=True): | 
| 715 | 715 | """ | 
| — | — | @@ -727,7 +727,7 @@ | 
| 728 | 728 | (count, start, addr)) | 
| 729 | 729 | self.emcore.ipodnano2g_nandwrite(addr, start, count, doecc) | 
| 730 | 730 | self.logger.info("done\n") | 
| 731 |  | -
 | 
|  | 731 | + | 
| 732 | 732 | @command | 
| 733 | 733 | def ipodnano2g_nanderase(self, addr, start, count): | 
| 734 | 734 | """ | 
| — | — | @@ -744,7 +744,7 @@ | 
| 745 | 745 | (count, start, addr)) | 
| 746 | 746 | self.emcore.ipodnano2g_nanderase(addr, start, count) | 
| 747 | 747 | self.logger.info("done\n") | 
| 748 |  | -
 | 
|  | 748 | + | 
| 749 | 749 | @command | 
| 750 | 750 | def ipodnano2g_dumpnand(self, filenameprefix): | 
| 751 | 751 | """ | 
| — | — | @@ -777,7 +777,7 @@ | 
| 778 | 778 | sparefile.close() | 
| 779 | 779 | statusfile.close() | 
| 780 | 780 | self.logger.info("done\n") | 
| 781 |  | -
 | 
|  | 781 | + | 
| 782 | 782 | @command | 
| 783 | 783 | def ipodnano2g_wipenand(self, filename, force=False): | 
| 784 | 784 | """ | 
| — | — | @@ -805,7 +805,7 @@ | 
| 806 | 806 | statusfile.write(self.emcore.read(0x08000000, 0x00000100)) | 
| 807 | 807 | statusfile.close() | 
| 808 | 808 | self.logger.info("done\n") | 
| 809 |  | -
 | 
|  | 809 | + | 
| 810 | 810 | @command | 
| 811 | 811 | def ipodclassic_writebbt(self, tempaddr, filename): | 
| 812 | 812 | """ | 
| — | — | @@ -822,7 +822,7 @@ | 
| 823 | 823 | data = self.emcore.ipodclassic_writebbt(f.read(), tempaddr) | 
| 824 | 824 | f.close() | 
| 825 | 825 | self.logger.info(" done\n") | 
| 826 |  | -
 | 
|  | 826 | + | 
| 827 | 827 | @command | 
| 828 | 828 | def getvolumeinfo(self, volume): | 
| 829 | 829 | """ | 
| — | — | @@ -836,7 +836,7 @@ | 
| 837 | 837 | self.logger.info("Vendor: %s\n" % data["vendor"]) | 
| 838 | 838 | self.logger.info("Product: %s\n" % data["product"]) | 
| 839 | 839 | self.logger.info("Revision: %s\n" % data["revision"]) | 
| 840 |  | -
 | 
|  | 840 | + | 
| 841 | 841 | @command | 
| 842 | 842 | def readrawstorage(self, volume, sector, count, addr): | 
| 843 | 843 | """ | 
| — | — | @@ -849,7 +849,7 @@ | 
| 850 | 850 | self.logger.info("Reading volume %s sectors %X - %X to %08X..." % (volume, sector, sector + count - 1, addr)) | 
| 851 | 851 | self.emcore.storage_read_sectors_md(volume, sector, count, addr) | 
| 852 | 852 | self.logger.info("done\n") | 
| 853 |  | -
 | 
|  | 853 | + | 
| 854 | 854 | @command | 
| 855 | 855 | def writerawstorage(self, volume, sector, count, addr): | 
| 856 | 856 | """ | 
| — | — | @@ -862,7 +862,7 @@ | 
| 863 | 863 | self.logger.info("Writing %08X to volume %s sectors %X - %X..." % (addr, volume, sector, sector + count - 1)) | 
| 864 | 864 | self.emcore.storage_write_sectors_md(volume, sector, count, addr) | 
| 865 | 865 | self.logger.info("done\n") | 
| 866 |  | -
 | 
|  | 866 | + | 
| 867 | 867 | @command | 
| 868 | 868 | def readrawstoragefile(self, volume, sector, count, file, buffsize = 0x100000, buffer = None): | 
| 869 | 869 | """ | 
| — | — | @@ -900,7 +900,7 @@ | 
| 901 | 901 | finally: | 
| 902 | 902 | f.close() | 
| 903 | 903 | self.logger.info("done\n") | 
| 904 |  | -
 | 
|  | 904 | + | 
| 905 | 905 | @command | 
| 906 | 906 | def writerawstoragefile(self, volume, sector, count, file, buffsize = 0x100000, buffer = None): | 
| 907 | 907 | """ | 
| — | — | @@ -942,7 +942,7 @@ | 
| 943 | 943 | finally: | 
| 944 | 944 | f.close() | 
| 945 | 945 | self.logger.info("done\n") | 
| 946 |  | -
 | 
|  | 946 | + | 
| 947 | 947 | @command | 
| 948 | 948 | def mkdir(self, dirname): | 
| 949 | 949 | """ | 
| — | — | @@ -951,7 +951,7 @@ | 
| 952 | 952 | self.logger.info("Creating directory %s..." % dirname) | 
| 953 | 953 | self.emcore.dir_create(dirname) | 
| 954 | 954 | self.logger.info(" done\n") | 
| 955 |  | -
 | 
|  | 955 | + | 
| 956 | 956 | @command | 
| 957 | 957 | def rmdir(self, dirname): | 
| 958 | 958 | """ | 
| — | — | @@ -960,7 +960,7 @@ | 
| 961 | 961 | self.logger.info("Removing directory %s..." % dirname) | 
| 962 | 962 | self.emcore.dir_remove(dirname) | 
| 963 | 963 | self.logger.info(" done\n") | 
| 964 |  | -
 | 
|  | 964 | + | 
| 965 | 965 | @command | 
| 966 | 966 | def rm(self, filename): | 
| 967 | 967 | """ | 
| — | — | @@ -969,7 +969,7 @@ | 
| 970 | 970 | self.logger.info("Removing file %s..." % filename) | 
| 971 | 971 | self.emcore.file_unlink(filename) | 
| 972 | 972 | self.logger.info(" done\n") | 
| 973 |  | -
 | 
|  | 973 | + | 
| 974 | 974 | @command | 
| 975 | 975 | def rmtree(self, path): | 
| 976 | 976 | """ | 
| — | — | @@ -987,7 +987,7 @@ | 
| 988 | 988 | except: break | 
| 989 | 989 | self.emcore.dir_close(handle) | 
| 990 | 990 | self.rmdir(path) | 
| 991 |  | -
 | 
|  | 991 | + | 
| 992 | 992 | @command | 
| 993 | 993 | def mv(self, oldname, newname): | 
| 994 | 994 | """ | 
| — | — | @@ -996,7 +996,7 @@ | 
| 997 | 997 | self.logger.info("Renaming %s to %s..." % (oldname, newname)) | 
| 998 | 998 | self.emcore.file_rename(oldname, newname) | 
| 999 | 999 | self.logger.info(" done\n") | 
| 1000 |  | -
 | 
|  | 1000 | + | 
| 1001 | 1001 | @command | 
| 1002 | 1002 | def get(self, remotename, localname, buffsize = 0x10000, buffer = None): | 
| 1003 | 1003 | """ | 
| — | — | @@ -1036,7 +1036,7 @@ | 
| 1037 | 1037 | finally: | 
| 1038 | 1038 | f.close() | 
| 1039 | 1039 | self.logger.info(" done\n") | 
| 1040 |  | -
 | 
|  | 1040 | + | 
| 1041 | 1041 | @command | 
| 1042 | 1042 | def gettree(self, remotepath, localpath, buffsize = 0x10000, buffer = None): | 
| 1043 | 1043 | """ | 
| — | — | @@ -1071,7 +1071,7 @@ | 
| 1072 | 1072 | self.emcore.free(buffer) | 
| 1073 | 1073 | finally: | 
| 1074 | 1074 | self.emcore.dir_close(handle) | 
| 1075 |  | -
 | 
|  | 1075 | + | 
| 1076 | 1076 | @command | 
| 1077 | 1077 | def put(self, localname, remotename, buffsize = 0x10000, buffer = None): | 
| 1078 | 1078 | """ | 
| — | — | @@ -1113,7 +1113,7 @@ | 
| 1114 | 1114 | finally: | 
| 1115 | 1115 | f.close() | 
| 1116 | 1116 | self.logger.info(" done\n") | 
| 1117 |  | -
 | 
|  | 1117 | + | 
| 1118 | 1118 | @command | 
| 1119 | 1119 | def puttree(self, localpath, remotepath, buffsize = 0x10000, buffer = None): | 
| 1120 | 1120 | """ | 
| — | — | @@ -1146,7 +1146,7 @@ | 
| 1147 | 1147 | finally: | 
| 1148 | 1148 | if malloc == True: | 
| 1149 | 1149 | self.emcore.free(buffer) | 
| 1150 |  | -
 | 
|  | 1150 | + | 
| 1151 | 1151 | @command | 
| 1152 | 1152 | def ls(self, path = "/"): | 
| 1153 | 1153 | """ | 
| Index: emcore/trunk/tools/libemcore.py | 
| — | — | @@ -617,7 +617,7 @@ | 
| 618 | 618 | self.lib.monitorcommand(struct.pack("IIII", 58, state, 0, 0), "III", (None, None, None)) | 
| 619 | 619 | if state != 0: self.logger.debug("Enabled FAT flushing\n") | 
| 620 | 620 | else: self.logger.debug("Disabled FAT flushing\n") | 
| 621 |  | -
 | 
|  | 621 | + | 
| 622 | 622 | @command(timeout = 30000) | 
| 623 | 623 | def file_open(self, filename, mode): | 
| 624 | 624 | """ Opens a file and returns the handle """ | 
| — | — | @@ -902,8 +902,8 @@ | 
| 903 | 903 | """ Frees all memory allocations created by the monitor thread """ | 
| 904 | 904 | self.logger.debug("Freeing all memory allocations created by the monitor thread\n") | 
| 905 | 905 | return self.lib.monitorcommand(struct.pack("IIII", 57, 0, 0, 0), "III", (None, None, None)) | 
| 906 |  | -    
 | 
| 907 | 906 |  | 
|  | 907 | + | 
| 908 | 908 | class Lib(object): | 
| 909 | 909 | def __init__(self, logger): | 
| 910 | 910 | self.logger = logger | 
| — | — | @@ -966,7 +966,7 @@ | 
| 967 | 967 |  | 
| 968 | 968 | self.interface = 0 | 
| 969 | 969 | self.timeout = 100 | 
| 970 |  | -
 | 
|  | 970 | + | 
| 971 | 971 | self.connect() | 
| 972 | 972 | self.findEndpoints() | 
| 973 | 973 |  |