Italian community of Lazarus and Free Pascal

Programmazione => Generale => Topic aperto da: bonmario - Gennaio 17, 2024, 09:14:11 am

Titolo: [RISOLTO]Windows: passaggio da Lazarus 32 a 64 bit ... gestione dll
Inserito da: bonmario - Gennaio 17, 2024, 09:14:11 am
Ciao a tutti,
al lavoro sto cercando di passare da Lazarus 32 quello a 64 bit.
Al momento ho un problema con le dll che mi permettono di connettermi al DB MicrosoftSql: dblib.dll e libiconv.dll, versione a 64 bit.
Le ho copiate in "C:\Windows\SysWOW64\", ma nonostante ciò continua a darmi l'errore
Codice: [Seleziona]
Can not load DB-lib client library "dblib.dll". Check your installation
Impossibile trovare il modulo specificato

Se invece prendo le 2 dll e le metto nella stessa directory dell'eseguibile, funziona tutto.

Qualcuno ha idea di cosa sto sbagliando?

Grazie, Mario
Titolo: Re:Windows: passaggio da Lazarus 32 a 64 bit ... gestione dll
Inserito da: xinyiman - Gennaio 17, 2024, 09:56:01 am
Ciao bonmario, premetto che non lavoro da un pezzo con SQL Server. Però anni fa quando ci giochicchiai un pochino mi era bastata l'opzione delle dll nella cartella dell'eseguibile.

Ricordo però anche (rimembranze da scuola superiore) che se vuoi usare una dll da cartella di sistema, la suddetta dll la devi registrare. Hai registrato la dll?!
Titolo: Re:Windows: passaggio da Lazarus 32 a 64 bit ... gestione dll
Inserito da: bonmario - Gennaio 17, 2024, 10:15:04 am
Ciao,
diciamo che sto cercando di capirne la logica, perché poi dovrò fare un lavoro analogo per PostgreSql ...

- Quando avevo fatto il lavoro con Lazarus 32 bit, mi ero scritto i passaggi fatti, ed era bastato copiare le 2 dll 32 bit in C:\Windows\System32 (senza registrarle)
- Ora le ho copiate in C:\Windows\SysWOW64, ma non funziona
- Se provo a registrarle, da prompt di DOS aperto come amministratore, mi dice di accertarmi che il file sia una dll valida. Stesso errore per tutte e 2 le dll
- Se prendo le stesse 2 dll, e le metto nella stessa directory dell'eseguibile, tutto funziona.

Io preferirei avere le dll in un posto unico, perché altrimenti le dovrei copiare in ogni cartella dei sorgenti che ne hanno bisogno e, quando poi sposto gli eseguibili nel posto corretto, dovrei copiarle anche lì.
Inoltre, se la cosa ha funzionato fino ad oggi con la versione 32 bit, perché non dovrebbe funzionare con quella 64 ?!?!?!?!

Ciao, Mario
Titolo: Re:Windows: passaggio da Lazarus 32 a 64 bit ... gestione dll
Inserito da: DragoRosso - Gennaio 17, 2024, 11:06:28 am
Ciao, ti esplicito alcuni elementi chiave per comprendere il funzionamento a 64 bit:

L'ambiente a 32 bit è di fatto emulato da Windows, ciò significa che alcune directory non sono esattamente come e dove pensi di trovarle, le principali sono:

1) SYSTEM32 di Windows esiste in 64 bit, ma un software a 32 bit vedrà la SYSWOW64;
2) Programmi -> "Program Files" in 64 bit, "Program Files (x86)" a 32 bit;

Registro di sistema (idem come sopra):

HKCU: è indifferente tra 64 bit e 32 bit;
HKLM: la voce SOFTWARE è per i 64 bit, i 32 bit useranno la sottovoce WOW6432Node (Computer\HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node)

TUTTO QUANTO SOPRA E' AUTOMATICO, cioè viene forzato da Windows, QUINDI I SOFTWARE anche vecchi potrebbero funzionare, fatto salvo che l'installazione sia in qualche modo compatibile con i criteri generali.

DLL:

questo è il cruccio generale di tutti. Dobbiamo distinguere due aspetti e precisamente il runtime e lo sviluppo.

1) RUNTIME: TUTTE LE DLL A RUNTIME DEVONO ESSERE DISPONIBILI PER LA VERSIONE CORRISPONDENTE DEL SW (64 o 32 bit) NELLA DIRECTORY DI ESECUZIONE o NELLA "PATH" DI SISTEMA. OCCHIO CHE VALE QUANTO DETTO SOPRA.

2) SVILUPPO: TUTTE LE DLL NECESSARIE ALLO SVILUPPO (AD ESEMPIO COMPONENTI DI TERZE PARTI) DEVONO ESSERE COMPATIBILI CON L'AMBIENTE DI SVILUPPO E PRESENTI NELLA "PATH" DI SISTEMA (O NELLE PATH DELL'AMBIENTE DI SVILUPPO).

Nel tuo caso, le DLL a 64 bit di Microsoft andrebbero nella SYSTEM32, le DLL a 32 bit invece nella SYSWOW64.

Non ci sono alternative a ciò. Puoi caricare le dll a 32 bit in System32, ma un app a 64 bit non funzionerà MAI.

Poi altro consiglio: tutte le librerie standard (ad esempio ridistribuite da componenti di Microsoft o da altri) andrebbe lasciate dove sono. Se proprio proprio non ti vanno bene li (ad esempio perchè devi redistribuirle) allora copiale nella tua directory dell'eseguibile (come hai già fatto).
Titolo: [RISOLTO]Windows: passaggio da Lazarus 32 a 64 bit ... gestione dll
Inserito da: bonmario - Gennaio 17, 2024, 11:06:46 am
Non ne capisco la logica, e non so cosa è cambiato da quando avevo fatto il lavoro con Lazarus 32 bit, ma mettendo insieme i pezzi di alcune info trovate in rete, alla fine ho risolto copiando le 2 dll in queste 3 directories:
Codice: [Seleziona]
C:\Lazarus\
C:\Windows\SysWOW64\
C:\Windows\System32\


Ciao, Mario
Titolo: Re:Windows: passaggio da Lazarus 32 a 64 bit ... gestione dll
Inserito da: DragoRosso - Gennaio 17, 2024, 11:14:21 am
Non ne capisco la logica, e non so cosa è cambiato da quando avevo fatto il lavoro con Lazarus 32 bit, ma mettendo insieme i pezzi di alcune info trovate in rete, alla fine ho risolto copiando le 2 dll in queste 3 directories:
Codice: [Seleziona]
C:\Lazarus\
C:\Windows\SysWOW64\
C:\Windows\System32\
Ciao, Mario
Ciò che è cambiato è che avevi copiato le directory DLL a 32 bit in SYSTEM32 ... questo ha fatto si che un software a 64 bit non potesse caricare quelle due DLL.

La logica di tutto questo è quella di mantener la compatibilità con il passato (32 bit) senza stravolgere nulla e di fatto software anche vecchi potrebbero girare senza problemi (sempre parlando di genericità)
Titolo: Re:Windows: passaggio da Lazarus 32 a 64 bit ... gestione dll
Inserito da: bonmario - Gennaio 17, 2024, 11:15:22 am
Nel tuo caso, le DLL a 64 bit di Microsoft andrebbero nella SYSTEM32, le DLL a 32 bit invece nella SYSWOW64.

Nel fare le mie prove, ho visto che, se copiavo le dll nella SYSTEM32, mi trovavo gli stessi files anche nella SYSWOW64, e viceversa.
La cosa strana è che quando ho copiato io manualmente le dll in entrambe le directories, il programma ha iniziato a non dare più errore !

Ciao, Mario