trancexx Posted September 20, 2013 Posted September 20, 2013 (edited) That beta version included some undocumented changes to the COM code which were later reverted because they were bad. Maybe there were similar type of changes (dumb type) for DllCall or structs too, maybe for some String functions too. Check contents of $_B64E_Init, $_B64E_EncodeData and $_B64E_EncodeEnd structures and see if you get any differences with betas that crash and AutoIt that works.Ward uses extended nop instructions to locate opcodes chunks. That means you can change that part of his code to this:$_B64E_Init = (StringInStr($Opcode, "89C0") + 1) / 2 $_B64E_EncodeData = (StringInStr($Opcode, "89DB") + 1) / 2 $_B64E_EncodeEnd = (StringInStr($Opcode, "89C9") + 1) / 2...which would eliminate those nop-s. Maybe some AutoIt compile options changed too, maybe it's some undocumented standard UDF change like those that were done for number of standard structures and that are script breaking as well as undocumented.Check MVP forum, in beta threads it can be seen that some non-developers influence development a lot, for bad really but still.Only Jon can give you answers to most of those questions. What's really weird is that it works for me. Edited September 20, 2013 by trancexx ♡♡♡ . eMyvnE
Beege Posted September 21, 2013 Posted September 21, 2013 This is working for me as well with Win 7 x64 3.3.9.19. I wonder if this is something to do with windows 8. Assembly Code: fasmg . fasm . BmpSearch . Au3 Syntax Highlighter . Bounce Multithreading Example . IDispatchASMUDFs: Explorer Frame . ITaskBarList . Scrolling Line Graph . Tray Icon Bar Graph . Explorer Listview . Wiimote . WinSnap . Flicker Free Labels . iTunesPrograms: Ftp Explorer . Snipster . Network Meter . Resistance Calculator
JScript Posted July 16, 2014 Posted July 16, 2014 @WardHello friend!Do I have any chance of having access to the source code of the following items:?Checksum CRC32 ADLER32 Compression LZMAIf not possible, no problem!Thank you,JS http://forum.autoitbrasil.com/ (AutoIt v3 Brazil!!!) Somewhere Out ThereJames Ingram Download Dropbox - Simplify your life!Your virtual HD wherever you go, anywhere!
Ward Posted July 17, 2014 Author Posted July 17, 2014 CRC32: unsigned long crc32(unsigned char* data, unsigned long len, unsigned long crc32, unsigned long poly) { unsigned long table[256], crc; int i, j; for(i = 0; i < 256; i++) { crc = i; for (j = 8; j > 0; j--) { if (crc & 1) crc = (crc >> 1) ^ poly; else crc >>= 1; } table[i] = crc; } for(i = 0; i < len; i++) { crc32 = (crc32 >> 8) ^ table[(crc32 ^ data[i]) & 0xFF]; } return crc32 ^ 0xFFFFFFFF; } ADLER32: #define MOD_ADLER 65521 int adler32(unsigned char* data, int len, unsigned int sum) { unsigned int tlen, a, b; a = sum & 0xffff; b = sum >> 16; while (len > 0) { tlen = len > 5552 ? 5552 : len; len -= tlen; do { a += *data++; b += a; } while (--tlen); a %= MOD_ADLER; b %= MOD_ADLER; } return (b << 16) | a; } LZMA: http://www.7-zip.org/sdk.html JScript 1 新版 _ArrayAdd 的白痴作者,不管是誰,去死一死好了。
JScript Posted July 17, 2014 Posted July 17, 2014 Thank you my friend!JS http://forum.autoitbrasil.com/ (AutoIt v3 Brazil!!!) Somewhere Out ThereJames Ingram Download Dropbox - Simplify your life!Your virtual HD wherever you go, anywhere!
wraithdu Posted July 30, 2014 Posted July 30, 2014 trancexxx's suggestion to change the '-3' to '+1' fixed the base64end crash I was experiencing on x64. However after looking through UEZ's base64 to string compression app and the LZMAT UDF here, there are some problems. I realize at the time that CallWindowProc was the hack used to make this kind of thing possible, however it's not necessary anymore since we have DllCallAddress. Under most circumstances the simple change is fine. However the case with LZMAT is troublesome. In that particular UDF (and perhaps others) the CallWindowProc parameters are being abused and this is leading to crashes on either x86 or x64 depending how it is modified. A good example of this is the _LZMAT_CodeDecompress function. The 3rd parameter to CallWindowProc is a UINT. This function's call to 'DllStructGetPtr($CodeBuffer) + $AP_Decompress' is passing a pointer in its place. On a x64 system this is a problem. It will work with DllCallAddress on x64 and CallWindowProc on x86, but not vice versa. I don't know why x86 doesn't work with DllCallAddress. I know it's been ages since you've updated these UDFs, but any chance you can redo them using DllCallAddress and sanity check the parameter passing?
KaFu Posted July 30, 2014 Posted July 30, 2014 I know it's not what you're asking for, but wouldn't some @AutoItX64 switches at the rights places do it in the meantime? OS: Win10-22H2 - 64bit - German, AutoIt Version: 3.3.16.1, AutoIt Editor: SciTE, Website: https://funk.eu AMT - Auto-Movie-Thumbnailer (2024-Oct-13) BIC - Batch-Image-Cropper (2023-Apr-01) COP - Color Picker (2009-May-21) DCS - Dynamic Cursor Selector (2024-Oct-13) HMW - Hide my Windows (2024-Oct-19) HRC - HotKey Resolution Changer (2012-May-16) ICU - Icon Configuration Utility (2018-Sep-16) SMF - Search my Files (2024-Oct-20) - THE file info and duplicates search tool SSD - Set Sound Device (2017-Sep-16)
wraithdu Posted July 30, 2014 Posted July 30, 2014 They are already there. But there has to be something up with the parameters the machine code is expecting. Without the function prototypes however, tough to know.
kara2004 Posted August 3, 2014 Posted August 3, 2014 (edited) Hello Ward, thank you for your excellent work. The UDF's work fine on Windows 7 (x64), but using them on Windows 8 causes some problems in x64-Applications (x86 works fine,too). For example in MD5.au3 I located the problem at the end of function "_MD5_CodeDecompress($Code)": Func _MD5_CodeDecompress($Code) ... Local $ResultLen = DllStructGetData(DllStructCreate("uint", DllStructGetPtr($Output)), 1) Local $Result = DllStructCreate("byte[" & ($ResultLen + 16) & "]") msgbox(0,"Trace","1") Local $Ret = DllCall("user32.dll", "uint", "CallWindowProc", "ptr", DllStructGetPtr($CodeBuffer) + $AP_Decompress, _ "ptr", DllStructGetPtr($Output) + 4, _ "ptr", DllStructGetPtr($Result), _ "int", 0, _ "int", 0) msgbox(0,"Trace","2") _MemVirtualFree($CodeBufferMemory, 0, $MEM_RELEASE) Return BinaryMid(DllStructGetData($Result, 1), 1, $Ret[0]) EndFunc Message "1" is shown, but then the app crashes: Problemsignatur: Problemereignisname: APPCRASH Anwendungsname: autoit3_x64.exe Anwendungsversion: 3.3.12.0 Anwendungszeitstempel: 538b66a5 Fehlermodulname: StackHash_76a1 Fehlermodulversion: 0.0.0.0 Fehlermodulzeitstempel: 00000000 Ausnahmecode: c0000005 Ausnahmeoffset: PCH_21 Betriebsystemversion: 6.2.9200.2.0.0.768.101 Gebietsschema-ID: 1031 Zusatzinformation 1: 76a1 Zusatzinformation 2: 76a173c26a6dc2e3cd83ac8fd9f8bdb9 Zusatzinformation 3: 7b3f Zusatzinformation 4: 7b3f634c955ac91fe3f1e745337a968a What's the problem ?? Thanks kara Edited August 3, 2014 by kara2004
Ward Posted August 5, 2014 Author Posted August 5, 2014 This is an old project... I will update these codes by using my new >BinaryCall UDF in someday. 新版 _ArrayAdd 的白痴作者,不管是誰,去死一死好了。
wraithdu Posted August 5, 2014 Posted August 5, 2014 I actually just saw that project and have been playing around with it. Very cool! Do you have the source code for these libraries published anywhere that we could take a hand at updating them?
prazetto Posted September 3, 2014 Posted September 3, 2014 Hi Ward, There is AP_Decompress machine code in every this Machine Code Algorithm Collection UDF to decompress that right called after base64 decoding every machine code embedded in UDF script. Mind you share the compressor itself. Or by the way what is algorithm name? Biatu 1 # Button. Progressbar - Graphical AutoIt3 Control (UDF) # GTK on AutoIt3 - GTK+ Framework | Widgets cig computer instruction graphics http://code.hstn.me
Lucid Posted May 18, 2016 Posted May 18, 2016 Ward, Is there any chance you could take a look into your AES.au3 code and see what it would take to get it to work when compiling to an x64 executable? I ran into an issue when using RTFC's CodeCryptor (https://www.autoitscript.com/forum/topic/155538-codecrypter-encrypt-your-script/). Everything works just fine when compiling to x86. It's just x64 that's causing me an issue (and of course, the bit of code I'm working on HAS to be x64). Thanks for all the hard work you did on everything! It's helped a TON!
Biatu Posted May 27, 2016 Posted May 27, 2016 Can someone post latest zip? Ward's files are MIA, and i use them all the time Thanks. What is what? What is what.
argumentum Posted May 28, 2016 Posted May 28, 2016 (edited) On 5/27/2016 at 1:44 AM, Biatu said: Can someone post latest zip? Ward's files are MIA, and i use them all the time Thanks. ok, attached below. AutoIt Machine Code Algorithm Collection ( in the file downloads section ) Edited August 6, 2018 by argumentum moved file to downloads Follow the link to my code contribution ( and other things too ). FAQ - Please Read Before Posting.
tubaba Posted August 6, 2018 Posted August 6, 2018 On 2016/5/28 at 7:23 PM, argumentum said: ok, attached below. AutoIt Machine Code Algorithm Collection.zip Thanks a lot, I've been looking for it for a long time. All links are invalid.
Jaycee1030 Posted November 25, 2020 Posted November 25, 2020 On 11/11/2010 at 3:03 PM, Ward said: CRC16 Hi i would to know if the udf for crc is still avaialble
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now