File tree Expand file tree Collapse file tree 2 files changed +30
-3
lines changed Expand file tree Collapse file tree 2 files changed +30
-3
lines changed Original file line number Diff line number Diff line change @@ -370,11 +370,19 @@ PHP_FUNCTION(msg_send)
370370		php_var_serialize (& msg_var , message , & var_hash );
371371		PHP_VAR_SERIALIZE_DESTROY (var_hash );
372372
373+ 		if  (UNEXPECTED (EG (exception ))) {
374+ 			smart_str_free (& msg_var );
375+ 			RETURN_THROWS ();
376+ 		}
377+ 
378+ 
379+ 		zend_string  * str  =  smart_str_extract (& msg_var );
380+ 		message_len  =  ZSTR_LEN (str );
373381		/* NB: php_msgbuf is 1 char bigger than a long, so there is no need to 
374382		 * allocate the extra byte. */ 
375- 		messagebuffer  =  safe_emalloc (ZSTR_LEN ( msg_var . s ) , 1 , sizeof (struct  php_msgbuf ));
376- 		memcpy (messagebuffer -> mtext , ZSTR_VAL (msg_var . s ), ZSTR_LEN ( msg_var . s )  +  1 );
377- 		message_len   =   ZSTR_LEN ( msg_var . s );
383+ 		messagebuffer  =  safe_emalloc (message_len , 1 , sizeof (struct  php_msgbuf ));
384+ 		memcpy (messagebuffer -> mtext , ZSTR_VAL (str ), message_len  +  1 );
385+ 		zend_string_release_ex ( str , false );
378386		smart_str_free (& msg_var );
379387	} else  {
380388		char  * p ;
Original file line number Diff line number Diff line change 1+ --TEST--
2+ msg_send() segfault when the type does not serialize as expected
3+ --EXTENSIONS--
4+ sysvmsg
5+ --FILE--
6+ <?php 
7+ class  Test {
8+     function  __serialize () {}
9+ }
10+ 
11+ $ qmsg_get_queue (1 );
12+ try  {
13+ 	msg_send ($ q1 , new  Test , true );
14+ } catch  (\TypeError   $ e
15+ 	echo  $ egetMessage ();
16+ }
17+ ?> 
18+ --EXPECT--
19+ Test::__serialize() must return an array
 
 
   
 
     
   
   
          
    
    
     
    
      
     
     
    You can’t perform that action at this time.
  
 
    
  
    
      
        
     
       
      
     
   
 
    
    
  
 
  
 
     
    
0 commit comments