Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unexpected escape in TableCommon.XXXRecord #60371

Open
lance6716 opened this issue Apr 2, 2025 · 0 comments
Open

Unexpected escape in TableCommon.XXXRecord #60371

lance6716 opened this issue Apr 2, 2025 · 0 comments
Labels
affects-7.1 This bug affects the 7.1.x(LTS) versions. affects-7.5 This bug affects the 7.5.x(LTS) versions. affects-8.1 This bug affects the 8.1.x(LTS) versions. type/enhancement The issue or PR belongs to an enhancement.

Comments

@lance6716
Copy link
Contributor

lance6716 commented Apr 2, 2025

Enhancement

in a performance test with TiDB v8.1.1 we found this variable is escaped where consumes 16% CPU

var value types.Datum

Image

pkg/table/tables/tables.go:924:7: value escapes to heap:
pkg/table/tables/tables.go:924:7:   flow: {heap} = &value:
pkg/table/tables/tables.go:924:7:     from &value (address-of) at pkg/table/tables/tables.go:959:126
pkg/table/tables/tables.go:924:7:     from (*TableCommon).appendInChangeColForChecksum(t, sctx, recordID, checksumData, (*table.Column).ToInfo(col), &r[col.ColumnInfo.ChangeStateInfo.DependencyColumnOffset], &value) (call parameter) at pkg/table/tables/tables.go:959:49
pkg/table/tables/tables.go:924:7: value escapes to heap:
pkg/table/tables/tables.go:924:7:   flow: {heap} = &value:
pkg/table/tables/tables.go:924:7:     from &value (address-of) at pkg/table/tables/tables.go:964:92
pkg/table/tables/tables.go:924:7:     from (*TableCommon).appendPublicColForChecksum(t, sctx, recordID, checksumData, (*table.Column).ToInfo(col), &value) (call parameter) at pkg/table/tables/tables.go:964:47
pkg/table/tables/tables.go:924:7: value escapes to heap:
pkg/table/tables/tables.go:924:7:   flow: {heap} = &value:
pkg/table/tables/tables.go:924:7:     from &value (address-of) at pkg/table/tables/tables.go:988:95
pkg/table/tables/tables.go:924:7:     from (*TableCommon).appendNonPublicColForChecksum(t, sctx, recordID, checksumData, (*table.Column).ToInfo(col), &value) (call parameter) at pkg/table/tables/tables.go:988:50
pk

Seems introduced by #43163 and unintentionally fixed by #53931

@lance6716 lance6716 added type/enhancement The issue or PR belongs to an enhancement. affects-7.1 This bug affects the 7.1.x(LTS) versions. affects-7.5 This bug affects the 7.5.x(LTS) versions. affects-8.1 This bug affects the 8.1.x(LTS) versions. affects-8.5 This bug affects the 8.5.x(LTS) versions. affects-9.0 This bug affects the 9.0.x versions. and removed affects-8.5 This bug affects the 8.5.x(LTS) versions. affects-9.0 This bug affects the 9.0.x versions. labels Apr 2, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
affects-7.1 This bug affects the 7.1.x(LTS) versions. affects-7.5 This bug affects the 7.5.x(LTS) versions. affects-8.1 This bug affects the 8.1.x(LTS) versions. type/enhancement The issue or PR belongs to an enhancement.
Projects
None yet
Development

No branches or pull requests

1 participant