HPE GreenLake Administration
- Community Home
- >
- Servers and Operating Systems
- >
- Operating Systems
- >
- Operating System - HP-UX
- >
- Re: Problem with "findpregtype".
Operating System - HP-UX
        1839270
        Members
    
    
        2779
        Online
    
    
        110137
        Solutions
    
Forums
        Categories
Company
Local Language
                
                  
                  back
                
        
                
        
                
        
                
        
        
        
                
        
                
        
        
        
                
        
              
              Forums
Discussions
Forums
- Data Protection and Retention
- Entry Storage Systems
- Legacy
- Midrange and Enterprise Storage
- Storage Networking
- HPE Nimble Storage
Discussions
Forums
Discussions
Discussions
Discussions
Forums
Discussions
                
                  
                  back
                
            
                
            
                
            
                
            
                
            
                
            
                
            
                
            
                
            
                
            
                
            
                
            
                
            
                
            
                
            
                
            
                
            
            
                
            
                
            
                
            
                
            
            
                
            
                
            
            
                
            
                
              
            Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
- BladeSystem Infrastructure and Application Solutions
- Appliance Servers
- Alpha Servers
- BackOffice Products
- Internet Products
- HPE 9000 and HPE e3000 Servers
- Networking
- Netservers
- Secure OS Software for Linux
- Server Management (Insight Manager 7)
- Windows Server 2003
- Operating System - Tru64 Unix
- ProLiant Deployment and Provisioning
- Linux-Based Community / Regional
- Microsoft System Center Integration
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Blogs
        Information
        Community
Resources
Community Language
        Language
        Forums
Blogs
	
		
			
            
                
            Go to solution
        
            
		
		
			
            	
	
		
        
		
	
	
		Topic Options
			
				
					
	
			
		
	- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Printer Friendly Page
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-30-2009 04:22 AM
11-30-2009 04:22 AM
			
				
					
					
						Hi All,
I am writing a device driver on HPUX. I am seeing different behavior of findpregtype() on debug and non debug HPUX OS.
findpregtype() in the code below is always returning “preg->p_reg” as NULL on debug version of HPUX (B.11.31.0903). But, it works correctly on PERF HPUX.
      
vas = p_vas(procp_self());
vas_read_lock(vas);
preg = findpregtype(vas, PT_TEXT, (struct kthread *)NULL);
vas_unlock(vas);
if (preg && preg->p_reg)
{
vp = preg->p_reg->r_fstore;
}
Please let me know if I am missing anything here.
					
				
			
			
				
	
			
				
		
			
			
			
			
			
			
		
		
		
	
	
	
I am writing a device driver on HPUX. I am seeing different behavior of findpregtype() on debug and non debug HPUX OS.
findpregtype() in the code below is always returning “preg->p_reg” as NULL on debug version of HPUX (B.11.31.0903). But, it works correctly on PERF HPUX.
vas = p_vas(procp_self());
vas_read_lock(vas);
preg = findpregtype(vas, PT_TEXT, (struct kthread *)NULL);
vas_unlock(vas);
if (preg && preg->p_reg)
{
vp = preg->p_reg->r_fstore;
}
Please let me know if I am missing anything here.
	"Study as if you were going to live forever; live as if you were going to die tomorrow."
			
			
				Solved! Go to Solution.
		3 REPLIES 3
	
	            
            
		
		
			
            
                - Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-30-2009 07:09 AM
11-30-2009 07:09 AM
Solution
			
				
					
					
						Well, the first thing that comes to mind is that if you have access to debug builds -- you shouldn't be asking *here*. Either you're with HP (which I can't determine to be true hence I have to reply to you here) or you're suitably supported that you should use your support channels.
No one outside of R&D development environments should ever be running true debug bits.
That aside -- there are a couple thoughts on your code snippet:
1) It is not safe to read the p_reg field of the pregion in general as you describe without the VAS lock held. Yes, it is your VAS -- but the region underlying the pregion could be changed by another thread in your process [perhaps the text is being made self-patching (write is granted) and needs to be changed to a private copy instead of the globally shared bopy... that's a new region and hence the old region might go away between your dropping the lock and reading the field -- interrupts can happen at any time and mean you can't wave this away with "I do this quickly"].
2) More to the point -- what you're describing makes me wonder if your driver is also compiled Debug when you link with the debug kernel. The usual culprit when I see this type of nonsense result (and it is nonsense -- the race I describe at (1) is possible but should be really rare, which means that usually reading your own VAS/text combination should work. You handle the daemon case by checking for NULL -- and if the pregion is non-NULL, it pretty much should have a region. The fact that you imply this is both repeatable and does not happen on a Perf kernel (when there's no difference between the two for this algorithm) suggests to me that you're really reading the *wrong field*. Which naturally flows if you're linking a perf-built driver to a debug kernel. The debug version of a pregion structure gains a lot of extra (debugging fields) in things like embedded locks, etc. The p_reg offset may easily just be pointing to garbage -- which you happen to see as NULL.
One way to confirm (2) would be to use the debugger or disassemble your driver code -- see where the offset referenced is on the perf versus debug kernels. If the offset is the same (as I suspect), then compare that with the fields of preg_t, and you should see what you're really reading.
		
		
	
	
	
No one outside of R&D development environments should ever be running true debug bits.
That aside -- there are a couple thoughts on your code snippet:
1) It is not safe to read the p_reg field of the pregion in general as you describe without the VAS lock held. Yes, it is your VAS -- but the region underlying the pregion could be changed by another thread in your process [perhaps the text is being made self-patching (write is granted) and needs to be changed to a private copy instead of the globally shared bopy... that's a new region and hence the old region might go away between your dropping the lock and reading the field -- interrupts can happen at any time and mean you can't wave this away with "I do this quickly"].
2) More to the point -- what you're describing makes me wonder if your driver is also compiled Debug when you link with the debug kernel. The usual culprit when I see this type of nonsense result (and it is nonsense -- the race I describe at (1) is possible but should be really rare, which means that usually reading your own VAS/text combination should work. You handle the daemon case by checking for NULL -- and if the pregion is non-NULL, it pretty much should have a region. The fact that you imply this is both repeatable and does not happen on a Perf kernel (when there's no difference between the two for this algorithm) suggests to me that you're really reading the *wrong field*. Which naturally flows if you're linking a perf-built driver to a debug kernel. The debug version of a pregion structure gains a lot of extra (debugging fields) in things like embedded locks, etc. The p_reg offset may easily just be pointing to garbage -- which you happen to see as NULL.
One way to confirm (2) would be to use the debugger or disassemble your driver code -- see where the offset referenced is on the perf versus debug kernels. If the offset is the same (as I suspect), then compare that with the fields of preg_t, and you should see what you're really reading.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
12-01-2009 01:21 AM
12-01-2009 01:21 AM
			
				
					
						
							Re: Problem with "findpregtype".
						
					
					
				
			
		
	
			
	
	
	
	
	
			
				
					
					
						>Don: One way to confirm (2) would be to use the debugger or disassemble your driver code
If it has debug info, you can get it to print out the offsets of each field.
gdb has "info types" and "ptype -v".
kwdb doesn't have -v but q4 has "fields -cv".
		
		
	
	
	
If it has debug info, you can get it to print out the offsets of each field.
gdb has "info types" and "ptype -v".
kwdb doesn't have -v but q4 has "fields -cv".
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
12-01-2009 04:28 AM
12-01-2009 04:28 AM
			
				
					
						
							Re: Problem with "findpregtype".
						
					
					
				
			
		
	
			
	
	
	
	
	
			
				
					
					
						Hi Don Morris I was able to solve the issue with your suggested 2nd point.
Thanks to Dennis also for replying to my query.
Closing the thread as script is working now.
		
		
	
	
	
Thanks to Dennis also for replying to my query.
Closing the thread as script is working now.
	"Study as if you were going to live forever; live as if you were going to die tomorrow."
			
			
				
			
			
			
			
			
			
		The opinions expressed above are the personal opinions of the authors, not of Hewlett Packard Enterprise. By using this site, you accept the Terms of Use and Rules of Participation.
		
	
	
Company
Events and news
Customer resources
© Copyright 2025 Hewlett Packard Enterprise Development LP
