| Author |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 | 
|  Posted: Fri 23 Jun '23 9:23    Post subject: |   |  
| 
 |  
| I can see I tried to build the extension for 7.4.29, but that one failed. So that was the end of an era. |  | 
| Back to top |  | 
| nambell 
 
 
 Joined: 22 Jun 2023
 Posts: 7
 
 
 | 
|  Posted: Tue 27 Jun '23 14:23    Post subject: |   |  
| 
 |  
| For correct enabling v8js extension I just need to write extension=v8js in php.ini? I already tried that, but It throws me an error that:
  	  | Code: |  	  | PHP Warning:  PHP Startup: Unable to load dynamic library 'C:/Custom-Server/SP/php74/ext/php_v8js.dll' in Unknown on line 0 | 
 I checked twice and this dll path is correct and file exists. Also I enabled bz2 extension and it loaded fine and without any error. Maybe there is any other libs that must be copied to apache/bin folder or anything else?
 |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 | 
|  Posted: Tue 27 Jun '23 15:31    Post subject: |   |  
| 
 |  
| Try putting the dependent dll's in your PHP-directory 
 v8.dll
 v8_libplatform.dll
 v8_libbase.dll
 icui18n.dll
 icuuc.dll
 
 icudtl.dat needs to be there as well. And this should ne in your php.ini:
 
 extension=v8js
 v8js.icudtl_dat_path=icudtl.dat
 |  | 
| Back to top |  | 
| nambell 
 
 
 Joined: 22 Jun 2023
 Posts: 7
 
 
 | 
|  Posted: Tue 27 Jun '23 16:14    Post subject: |   |  
| 
 |  
|  	  | Jan-E wrote: |  	  | v8.dll v8_libplatform.dll
 v8_libbase.dll
 icui18n.dll
 icuuc.dll
 | 
 These files are already in the directory, cuz I'm using your php build, which you mentioned before. If I write something like this:
  	  | Code: |  	  | extension_dir = "C:/Custom-Server/SP/php74/ext" extension = v8js
 v8js.icudtl_dat_path = icudtl.dat
 | 
 then it display me that error:
 
  	  | Code: |  	  | PHP Warning: PHP Startup: Unable to load dynamic library 'v8js' (tried: C:/Custom-Server/SP/php74/ext\\v8js (The specified module was not found.), C:/Custom-Server/SP/php74/ext\\php_v8js.dll (The specified module was not found.)) in Unknown on line 0 | 
 I also noticed that for some reason it adds a second backslash to the full path of dll, maybe because of this it is not possible to enable the extension?
 |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 | 
|  Posted: Tue 27 Jun '23 16:45    Post subject: |   |  
| 
 |  
| Does it load other extensions with dependencies? 
 extension=pdflib
 extension=ldap
 extension=amqp
 extension=mbstring
 extension=openssl
 
 If they fail as well you have a general PHP-installation problem, not related to v8js. Then try to get a running PHP 7.4 before adding v8js.
 |  | 
| Back to top |  | 
| nambell 
 
 
 Joined: 22 Jun 2023
 Posts: 7
 
 
 | 
|  Posted: Wed 28 Jun '23 8:09    Post subject: |   |  
| 
 |  
|  	  | Jan-E wrote: |  	  | Does it load other extensions with dependencies? 
 | 
 Nope, same error on each extension.
 
 Fixed it with adding full path to php folder & ext folder to PATH variable in environment variable for user and system. Now all works as it must.
 |  | 
| Back to top |  | 
| Deadooshka 
 
 
 Joined: 06 Jan 2018
 Posts: 4
 
 
 | 
|  Posted: Thu 06 Jul '23 17:34    Post subject: PHP 8.3.0 Alpha 2 |   |  
| 
 |  
| Can't run 8.3 on Windows 7. It requires GetCurrentThreadStackLimits system function. Is that official support ending for Windows 7? |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 | 
|  Posted: Sat 08 Jul '23 22:23    Post subject: Re: PHP 8.3.0 Alpha 2 |   |  
| 
 |  
|  	  | Deadooshka wrote: |  	  | Can't run 8.3 on Windows 7. It requires GetCurrentThreadStackLimits system function. Is that official support ending for Windows 7? | 
 Ouch. Looks like this is unintentional. The commit that introduced GetCurrentThreadStackLimits stated:
 
  	  | Quote: |  	  | Minimum supported Windows version bumped to Windows 2008 or Windows Server 2012 | 
 Windows 2008 is the server equivalent of Windows 7. And I checked: PHP 8.3 (nts x64) does not run on Windows 2008 R2 either.
 
 I reported this to the PHP devs:
 https://github.com/php/php-src/pull/9104#issuecomment-1627481475
 |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 |  | 
| Back to top |  | 
| tmabell 
 
 
 Joined: 23 Jun 2023
 Posts: 8
 Location: Mishawaka, IN
 
 | 
|  Posted: Thu 20 Jul '23 15:55    Post subject: |   |  
| 
 |  
| Are you referring to Windows 7 or Windows 7 SP1 or both? 
 
 |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 | 
|  Posted: Thu 20 Jul '23 16:07    Post subject: |   |  
| 
 |  
|  	  | tmabell wrote: |  	  | Are you referring to Windows 7 or Windows 7 SP1 or both? 
 
 | 
 Both
 |  | 
| Back to top |  | 
| maxrys 
 
 
 Joined: 12 Oct 2023
 Posts: 1
 Location: Minsk
 
 | 
|  Posted: Thu 12 Oct '23 17:34    Post subject: |   |  
| 
 |  
|  	  | Otomatic wrote: |  	  | virtualprotect() failed 87 the parameter is incorrect. | 
 
 About "virtualprotect() failed 87 the parameter is incorrect"...
 
 I was investigating the same case.
 
 I tested CMS EFFCORE on the Windows platform (Windows 10 2021 LTSC x64).
 
 After installing Apache (httpd-2.4.57-win64-VS17.zip) and PHP (php-8.2.11-vs16-x64.zip), I began to include the missing modules to install the system.
 
 I enabled all the required modules and the system installed without problems.
 
 I ran all the tests and they ran successfully.
 
 Then I decided to speed up the system and enabled OPCache + JIT.
 
 After enabling OPCache + JIT I started getting a "white screen" and the message "virtualprotect() failed 87 the parameter is incorrect".
 
 After disabling OPCache + JIT or OPCache the problem went away.
 
 I was wondering what this error was.
 
 I created a small script and placed it in the "test.php" file.
 
 It had the following contents:
 
 
  	  | Code: |  	  | $path = 'data.php'; $lines_num = 2000;
 if (!file_exists($path)) {
 file_put_contents($path, '<?php'."\n", FILE_APPEND);
 for ($i = 0; $i < $lines_num; $i++)
 file_put_contents($path, '$data['.$i.'] = \'value '.$i."';\n", FILE_APPEND);
 file_put_contents($path, 'print \'COUNT: \'.count($data);', FILE_APPEND);
 print 'FILE WAS CREATED. RELOAD THIS PAGE';
 } else {
 include_once($path);
 print "\n".'FILE WAS INCLUDED';
 }
 | 
 
 Next, I ran “test.php” from the browser and got a white screen if “lines_num” was greater than 2000 and a normal result if less than 2000.
 This is an obvious overflow of some memory segment.
 However, the log did not contain any information about the error.
 
 From the console I ran this script with any number of "lines_num" and no problems arose.
 
 
  	  | Code: |  	  | php -d opcache.jit_debug=1 test.php php -d opcache.jit_debug=1 data.php
 | 
 
 I concluded that the problem is with the Apache + PHP combination as a module.
 However, there were no problems under Linux/Unix.
 
 Here is the complete list of links:
 - win: Apache + PHP as a module - !!! JIT problem !!!
 - win: IIS + PHP as FastCGI - OK
 - win: PHP CLI - OK
 - nix: Apache + PHP as a module - OK
 - nix: NGINX + PHP as FastCGI - OK
 - nix: PHP CLI - OK
 
 I had to disable OPCache in "php.ini" via "opcache.enable=0" and the problem went away.
 
 In "php.ini" you can disable only JIT via "opcache.jit_buffer_size=0" but this setting cannot be changed directly from PHP code.
 
 Changing other "opcache.*" settings in "php.ini" did not lead to anything.
 
 You can also disable OPCache + JIT programmatically with the following code:
 
 
  	  | Code: |  	  | if (DIRECTORY_SEPARATOR === '\\') { ini_set('opcache.enable', false);
 }
 | 
 
 Thank you for your attention, I hope it helped.
 |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 | 
|  Posted: Sat 09 Dec '23 0:40    Post subject: |   |  
| 
 |  
| All 8.x builds updated to OpenSSL 3.0.12 and Curl 8.5.0, including PHP 8.1.27RC1. |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 | 
|  Posted: Wed 17 Jul '24 13:17    Post subject: |   |  
| 
 |  
| PHP 8.4 is on its way. As of 8.4.0 Alpha 2 it builds fine with Visual Studio 2022 aka VS17. The PHP devs stick to their preference for the OpenSSL LTS branch, which is 3.0.x. |  | 
| Back to top |  | 
| BrainFooLong 
 
 
 Joined: 31 May 2023
 Posts: 5
 
 
 | 
|  Posted: Fri 19 Jul '24 7:05    Post subject: |   |  
| 
 |  
|  	  | Jan-E wrote: |  	  | PHP 8.4 is on its way. As of 8.4.0 Alpha 2 it builds fine with Visual Studio 2022 aka VS17. The PHP devs stick to their preference for the OpenSSL LTS branch, which is 3.0.x. | 
 
 Very nice. Works fine here, however i see "php_sqlsrv" extension is missing currently. Is it incompatible with PHP 8.4 as of now?
 |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 | 
|  Posted: Thu 25 Jul '24 0:37    Post subject: |   |  
| 
 |  
|  	  | BrainFooLong wrote: |  	  |  	  | Jan-E wrote: |  	  | PHP 8.4 is on its way. As of 8.4.0 Alpha 2 it builds fine with Visual Studio 2022 aka VS17. The PHP devs stick to their preference for the OpenSSL LTS branch, which is 3.0.x. | 
 Very nice. Works fine here, however i see "php_sqlsrv" extension is missing currently. Is it incompatible with PHP 8.4 as of now?
 | 
 It is. But a solution is in the making: https://github.com/microsoft/msphpsql/issues/1507
 |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 | 
|  Posted: Thu 25 Jul '24 12:41    Post subject: |   |  
| 
 |  
|  	  | Jan-E wrote: |  	  |  	  | BrainFooLong wrote: |  	  |  	  | Jan-E wrote: |  	  | PHP 8.4 is on its way. As of 8.4.0 Alpha 2 it builds fine with Visual Studio 2022 aka VS17. The PHP devs stick to their preference for the OpenSSL LTS branch, which is 3.0.x. | 
 Very nice. Works fine here, however i see "php_sqlsrv" extension is missing currently. Is it incompatible with PHP 8.4 as of now?
 | 
 It is. But a solution is in the making: https://github.com/microsoft/msphpsql/issues/1507
 | 
 All builds of 8.4.0 Alpha 2 contain the SQLSRV extensions (php_sqlsrv.dll and php_pdo_sqlsrv.dll) now.
 
 @BrainFooLong If you have got a running SQL Server, could you test if this very early release has major issues? I cannot solve them but once PHP 8.4.0 is in the RC state issues should be filed at https://github.com/microsoft/msphpsql/issues
 |  | 
| Back to top |  | 
| BrainFooLong 
 
 
 Joined: 31 May 2023
 Posts: 5
 
 
 | 
|  Posted: Wed 31 Jul '24 9:14    Post subject: |   |  
| 
 |  
| @Jan-E 
 I can confirm this current 8.4.0 Alpha 2 does contain SQLSRV
 and it works.
 
 I've tested my use cases (Mostly selects and inserts) and all works like a charm.
 
 Thank you.
 |  | 
| Back to top |  | 
| Jan-E 
 
 
 Joined: 09 Mar 2012
 Posts: 1283
 Location: Amsterdam, NL, EU
 
 | 
|  Posted: Wed 31 Jul '24 19:38    Post subject: |   |  
| 
 |  
| @BrainFooLong Thanks for testing! PHP 8.4.0 Alpha 3 is available now. From now on until the final release of PHP 8.4.0 there will be an alpha, beta or RC of 8.4.0. |  | 
| Back to top |  |