[squeak-dev] The Trunk: Compiler-mt.406.mcz

Levente Uzonyi leves at caesar.elte.hu
Thu Jul 25 21:08:09 UTC 2019


Hi Marcel,

On Wed, 24 Jul 2019, commits at source.squeak.org wrote:

> Marcel Taeumel uploaded a new version of Compiler to project The Trunk:
> http://source.squeak.org/trunk/Compiler-mt.406.mcz
>
> ==================== Summary ====================
>
> Name: Compiler-mt.406
> Author: mt
> Time: 24 July 2019, 5:10:22.611145 pm
> UUID: 6d65ea45-4488-471b-a9cf-b4a16cac35f3
> Ancestors: Compiler-mt.405
>
> Minor performance improvement for has-literal checks. Thanks to Levente for the ideas!
>
> Still not sure about putting true/false/nil-checks to the top. Also not sure the complex return blocks for symbol/character/integer.

The code is fine as-is. I doubt it needed optimization in the first place. 
I would even consider turning the branches of true, false, nil and ^false 
back into a single boolean expression, but I don't think it's worth to 
spend more time and SqueakSource resources on this.

Performance-wise, this version is pretty good. The ugly and weird JIT hack 
to use ifTrue:ifFalse: with explicit returns could boost it a bit. E.g.:

 	aLiteral isSymbol ifTrue: [
 		(Smalltalk specialSelectors identityIncludes: aLiteral) ifTrue: [ ^true ].
 		^false ]
instead of

  	aLiteral isSymbol ifTrue: [^ Smalltalk specialSelectors identityIncludes: aLiteral].


Levente

>
> =============== Diff against Compiler-mt.405 ===============
>
> Item was changed:
>  ----- Method: BytecodeEncoder class>>canBeSpecialLiteral: (in category 'testing') -----
>  canBeSpecialLiteral: aLiteral
> + 	"This check can be used to prevent unnecessary use of #scanBlockOrNilForLiteral:. For performance, this method summarizes specializations from all known bytecode encoders. It is not meant to be refined per bytecode encoder."
> - 	"This check can be used to prevent unnecessary use of #scanBlockOrNilForLiteral:. For performance, this method summarizes specializations from all known bytecode encoders. It is not meant to be refined per encoder."
> 
> + 	aLiteral isSymbol ifTrue: [^ Smalltalk specialSelectors identityIncludes: aLiteral].
> + 	aLiteral isCharacter ifTrue: [^ aLiteral asInteger <= 65535].
> + 	aLiteral isInteger ifTrue: [^ aLiteral between: -32768 and: 32767].
> + 
> + 	aLiteral == true ifTrue: [^ true].
> + 	aLiteral == false ifTrue: [^ true].
> + 	aLiteral == nil ifTrue: [^ true].
> + 
> + 	^ false!
> - 	^ ((((((aLiteral isSymbol and: [Smalltalk specialSelectors includes: aLiteral])
> - 		or: [aLiteral isInteger and: [aLiteral between: -32768 and: 32767]])
> - 		or: [aLiteral isCharacter and: [aLiteral asInteger <= 65535]])
> - 		or: [aLiteral == true])
> - 		or: [aLiteral == false])
> - 		or: [aLiteral == nil])!


More information about the Squeak-dev mailing list