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

Refactor: Prerequisite for AutoScheduler #362

Merged
merged 57 commits into from
Dec 22, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
57 commits
Select commit Hold shift + click to select a range
6782d42
gemm
hikettei Dec 20, 2024
44a490f
Tile
hikettei Dec 20, 2024
610316a
search tile
hikettei Dec 20, 2024
0cd518a
Merge branch 'main' into opt-gemm
hikettei Dec 20, 2024
f6bcc57
OpenBLAS
hikettei Dec 20, 2024
253cf6f
90GFLops
hikettei Dec 20, 2024
d4c08c4
wip
hikettei Dec 20, 2024
db52790
wip
hikettei Dec 20, 2024
082ae9d
wip
hikettei Dec 20, 2024
9446987
tile param search
hikettei Dec 20, 2024
6a92698
finish an experiment
hikettei Dec 20, 2024
0e435c1
apply tiling without causing segv
hikettei Dec 20, 2024
e32cec2
tiling all bands
hikettei Dec 20, 2024
c4215bc
things are moved
hikettei Dec 20, 2024
4c2de70
move everything into auto-scheduler
hikettei Dec 21, 2024
785d2eb
asd
hikettei Dec 21, 2024
34656d2
fix: tiling-size related gc error
hikettei Dec 21, 2024
6a0c211
An initial attempt to unroll: tile based
hikettei Dec 21, 2024
0ab186d
moved
hikettei Dec 21, 2024
2ce3075
split
hikettei Dec 21, 2024
b22d20f
.
hikettei Dec 21, 2024
874cd17
moved isl things to auto-scheduler
hikettei Dec 21, 2024
b47fd09
refactor
hikettei Dec 21, 2024
e92725d
synchronize baseline
hikettei Dec 21, 2024
e1e5dc7
updt
hikettei Dec 21, 2024
dfca38d
updt
hikettei Dec 21, 2024
0ed2740
typo
hikettei Dec 21, 2024
0adb742
typo
hikettei Dec 21, 2024
378c310
typo
hikettei Dec 21, 2024
d2de5a1
Tweak
hikettei Dec 21, 2024
cd01fe9
nested unroll directive
hikettei Dec 21, 2024
64b8c7c
Unroll for static and simple case
hikettei Dec 21, 2024
3ac9213
Fold MOD
hikettei Dec 21, 2024
0d4095f
nope
hikettei Dec 21, 2024
642acc9
Initial attempt of unrolling
hikettei Dec 21, 2024
ea829fd
copy and remove UNROLL_PARENT for the reminder
hikettei Dec 21, 2024
b7ba19f
Loop Unrolling is worked
hikettei Dec 21, 2024
6df4461
Unrolling softmax
hikettei Dec 21, 2024
994a615
wip: generating a sketch
hikettei Dec 21, 2024
ca032f8
Identify the sketch
hikettei Dec 21, 2024
4cdec95
TODO
hikettei Dec 21, 2024
1c5096e
remove extra unroll reminder
hikettei Dec 21, 2024
bfb2d11
coincident for elwise
hikettei Dec 22, 2024
771fa79
fix: unroll
hikettei Dec 22, 2024
aad075a
quickload
hikettei Dec 22, 2024
1b56342
MemoryPlanner should produce the same result
hikettei Dec 22, 2024
e77703a
Fix for unroll reminder
hikettei Dec 22, 2024
0e9fff8
try unrolling tiled bands
hikettei Dec 22, 2024
6674d7b
ignore tiled band dims
hikettei Dec 22, 2024
ce60a52
base-item
hikettei Dec 22, 2024
5ba4fa3
remove: caten/polyhedral
hikettei Dec 22, 2024
26a4a66
clean up
hikettei Dec 22, 2024
e63ac07
rem dep
hikettei Dec 22, 2024
546d0c4
caten instead
hikettei Dec 22, 2024
f73c49f
updt
hikettei Dec 22, 2024
04cb131
updt
hikettei Dec 22, 2024
c832f5e
updt
hikettei Dec 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix: tiling-size related gc error
  • Loading branch information
hikettei committed Dec 21, 2024
commit 34656d2ee20708eacdb5ef8496da1bd500ecb614
12 changes: 7 additions & 5 deletions source/codegen/auto-scheduler/tiling.lisp
Original file line number Diff line number Diff line change
Expand Up @@ -54,13 +54,14 @@ To apply tiling to a reduce dim, use apply-tiling.
partial-schedule))

(defun schedule-tile-band (band &key (size-default 32) (dims))
"Tiling sizes can be given by either of size-default or dims. If dims is set to nil, size-default is used.
dims is used to specify the tiling sizes for each dimension."
(multiple-value-bind (partial-schedule shift)
(shift-band-zero band)
(let* ((tiling-sizes (tiling-sizes band :size-default size-default :dims dims))
(partial-schedule (tile-partial-schedule partial-schedule tiling-sizes))
(tiled-sched (multi-union-pw-aff-add partial-schedule shift)))
(schedule-node-get-schedule
(schedule-node-insert-partial-schedule band tiled-sched)))))
(schedule-node-insert-partial-schedule band tiled-sched))))

(defun get-tileable-bands (poly)
(map-schedule-nodes #'(lambda (type node) (when (eql type :schedule-node-band) node)) poly))
Expand All @@ -76,6 +77,7 @@ To apply tiling to a reduce dim, use apply-tiling.
(dotimes (i (length bands))
(let ((i (- (1- (length bands)) i)))
(setf (poly-schedule ir)
(schedule-tile-band
(nth i (get-tileable-bands ir))
:size-default size))))))
(schedule-node-get-schedule
(schedule-tile-band
(nth i (get-tileable-bands ir))
:size-default size)))))))
15 changes: 13 additions & 2 deletions source/codegen/auto-scheduler/unroll.lisp
Original file line number Diff line number Diff line change
@@ -1,14 +1,25 @@
(defpackage :caten/codegen/unroll
(:use :cl :caten/aasm :caten/air :caten/codegen/polyhedral)
(:import-from
:caten/codegen/tiling
#:tiling-sizes)
(:export #:apply-packed-funcall))

(in-package :caten/codegen/unroll)

(defun schedule-node-band-apply-unroll (schedule-node)
(declare (type isl::schedule-node schedule-node))
(print "UNROLL")
(let* ((tiled-schedule (isl:schedule-node-band-tile schedule-node (tiling-sizes schedule-node :size-default 16)))
(tiled-schedule (isl:schedule-node-get-child tiled-schedule 0))
(tiled-schedule (isl:schedule-node-band-set-ast-build-options tiled-schedule (isl:union-set-from-str "{ unroll[4] }"))))
(isl:schedule-node-get-schedule schedule-node)))

(defun schedule-apply-schedule-option (si idx)
(declare (type Polyhedral-IR si))
(let ((bands (map-schedule-nodes #'(lambda (type node) (when (eql type :schedule-node-band) node)) si)))
(print bands)
))
(when bands
(setf (poly-schedule si) (schedule-node-band-apply-unroll (first bands))))))

(defun apply-packed-funcall (schedule-node gid unroll-by)
"Groups the iteration into several packed-funcall.
Expand Down
2 changes: 1 addition & 1 deletion source/codegen/caten.codegen.asd
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,10 @@
(:file "exprify")
(:file "blueprint")
(:file "polyhedral-ast")
(:file "auto-scheduler/polyhedral")
(:file "scop")
(:file "auto-scheduler/auto-scheduler")
(:file "auto-scheduler/config")
(:file "auto-scheduler/polyhedral")
(:file "auto-scheduler/coincidence")
(:file "auto-scheduler/tiling")
(:file "auto-scheduler/unroll")
Expand Down
1 change: 1 addition & 0 deletions source/isl/package.lisp
Original file line number Diff line number Diff line change
Expand Up @@ -370,6 +370,7 @@
#:schedule-node-band-set-ast-build-options
#:schedule-node-delete
#:schedule-node-first-child
#:schedule-node-band-tile
#:schedule-node-insert-mark
#:schedule-node-graft-after
#:schedule-node-graft-before
Expand Down
5 changes: 5 additions & 0 deletions source/isl/schedule-node.lisp
Original file line number Diff line number Diff line change
Expand Up @@ -124,3 +124,8 @@
(:give schedule-node)
(:take schedule-node)
(:take union-set))

(define-isl-function schedule-node-band-tile %isl-schedule-node-band-tile
(:give schedule-node)
(:take schedule-node)
(:take multi-val))
2 changes: 1 addition & 1 deletion source/isl/value.lisp
Original file line number Diff line number Diff line change
Expand Up @@ -154,5 +154,5 @@
(ls (%make-value-list (%isl-val-list-alloc (context-handle *context*) n))))
(loop for value in value-list
for nth upfrom 0
do (%isl-val-list-add (value-list-handle ls) (value-handle value)))
do (%isl-val-list-add (value-list-handle ls) (value-handle (copy value))))
ls))
Loading