- 
    Sub-task 
- 
    Resolution: Fixed
- 
     P4 P4
- 
    25
                    The downcallHandle method in Linker has a complex implementation, and type switches is triggered in multiple places in that handle.
After bytestacks analysis of a simple program that links the native implementation of Class::forName0, it turns out that:
1. there are a few missed usages of type switch in ClassFile API
2. type switch can speed up generation by using explicit stack maps, as stack map gen is over 50% of the generation instructions because the switch is branch-heavy, but the frames are actually simple.
These two combined are not that significant in the overall overhead of downcallHandle, but would be helpful for other workloads.
After bytestacks analysis of a simple program that links the native implementation of Class::forName0, it turns out that:
1. there are a few missed usages of type switch in ClassFile API
2. type switch can speed up generation by using explicit stack maps, as stack map gen is over 50% of the generation instructions because the switch is branch-heavy, but the frames are actually simple.
These two combined are not that significant in the overall overhead of downcallHandle, but would be helpful for other workloads.
- relates to
- 
                    JDK-8355335 Avoid pattern matching switches in core ClassFile API -           
- Resolved
 
-         
- links to
- 
                     Commit(master)
        openjdk/jdk/bd1c53e9 Commit(master)
        openjdk/jdk/bd1c53e9
- 
                     Review(master)
        openjdk/jdk/24705 Review(master)
        openjdk/jdk/24705