Subversion Repositories Kolibri OS

Rev

Rev 5078 | Rev 6104 | Go to most recent revision | Only display areas with differences | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 5078 Rev 5271
1
CC = gcc
-
 
2
LD = ld
-
 
3
AS = as
1
CC = gcc
4
FASM = fasm.exe
2
LD = ld
5
 
3
AS = as
6
DEFINES	 = -D__KERNEL__ -DCONFIG_X86_32 
4
FASM = fasm.exe
-
 
5
 
7
 
6
DEFINES	 = -D__KERNEL__ -DCONFIG_X86_32 -DCONFIG_TINY_RCU -DCONFIG_X86_L1_CACHE_SHIFT=6
8
DRV_TOPDIR   = $(CURDIR)/../../..
7
DEFINES += -DCONFIG_ARCH_HAS_CACHE_LINE_SIZE
9
DRM_TOPDIR   = $(CURDIR)/..
8
 
10
 
9
DRV_TOPDIR   = $(CURDIR)/../../..
11
DRV_INCLUDES = $(DRV_TOPDIR)/include
10
DRM_TOPDIR   = $(CURDIR)/..
12
 
11
 
13
INCLUDES = 	-I$(DRV_INCLUDES) -I$(DRV_INCLUDES)/drm	\
12
DRV_INCLUDES = $(DRV_TOPDIR)/include
14
		-I$(DRV_INCLUDES)/linux
13
 
15
 
14
INCLUDES =	-I$(DRV_INCLUDES)	\
-
 
15
		-I$(DRV_INCLUDES)/asm 	\
-
 
16
		-I$(DRV_INCLUDES)/uapi	\
16
CFLAGS   = -c -Os $(INCLUDES) $(DEFINES) -march=i686 -fomit-frame-pointer -fno-builtin-printf
17
		-I$(DRV_INCLUDES)/drm -I./ -I$(DRV_INCLUDES)
-
 
18
 
17
 
19
CFLAGS= -c -O2 $(INCLUDES) $(DEFINES) -march=i686 -fno-ident -fomit-frame-pointer -fno-builtin-printf
18
LIBPATH:= $(DRV_TOPDIR)/ddk
20
CFLAGS+= -mno-stack-arg-probe -mpreferred-stack-boundary=2 -mincoming-stack-boundary=2 -mno-ms-bitfields
19
 
21
 
20
LIBS:=    -lddk -lcore -lgcc
22
LIBPATH:= $(DRV_TOPDIR)/ddk
21
 
23
 
22
LDFLAGS = -nostdlib -shared -s -Map atikms.map --image-base 0\
24
LIBS:=    -lddk -lcore -lgcc
23
	  --file-alignment 512 --section-alignment 4096
25
 
24
 
26
LDFLAGS = -nostdlib -shared -s -Map atikms.map --image-base 0\
25
 
27
	  --file-alignment 512 --section-alignment 4096
26
NAME:=	  atikms
28
 
27
 
29
 
28
HFILES:=     		$(DRV_INCLUDES)/linux/types.h		\
30
NAME:=	  atikms
29
			$(DRV_INCLUDES)/linux/list.h		\
31
 
30
			$(DRV_INCLUDES)/linux/pci.h		\
32
HFILES:=     		$(DRV_INCLUDES)/linux/types.h		\
31
			$(DRV_INCLUDES)/drm/drm.h		\
33
			$(DRV_INCLUDES)/linux/list.h		\
32
			$(DRV_INCLUDES)/drm/drmP.h		\
34
			$(DRV_INCLUDES)/linux/pci.h		\
33
			$(DRV_INCLUDES)/drm/drm_edid.h		\
-
 
34
			$(DRV_INCLUDES)/drm/drm_crtc.h		\
35
			$(DRV_INCLUDES)/drm/drmP.h		\
35
			$(DRV_INCLUDES)/drm/drm_mm.h		\
36
			$(DRV_INCLUDES)/drm/drm_edid.h		\
36
			atom.h					\
37
			$(DRV_INCLUDES)/drm/drm_crtc.h		\
37
			radeon.h				\
38
			$(DRV_INCLUDES)/drm/drm_mm.h		\
38
			radeon_asic.h
39
			atom.h					\
39
 
40
			radeon.h				\
40
NAME_SRC=							\
41
			radeon_asic.h
41
			main.c					\
42
 
42
			pci.c					\
43
NAME_SRC=							\
43
			../ttm/ttm_bo.c				\
44
			main.c					\
44
			../ttm/ttm_bo_manager.c			\
45
			pci.c					\
45
			../ttm/ttm_bo_util.c			\
46
			../ttm/ttm_bo.c				\
46
			../ttm/ttm_execbuf_util.c		\
47
			../ttm/ttm_bo_manager.c			\
47
			../ttm/ttm_memory.c			\
48
			../ttm/ttm_bo_util.c			\
48
			../ttm/ttm_page_alloc.c			\
49
			../ttm/ttm_execbuf_util.c		\
49
			../ttm/ttm_tt.c				\
50
			../ttm/ttm_memory.c			\
50
			$(DRM_TOPDIR)/drm_cache.c		\
51
			../ttm/ttm_page_alloc.c			\
51
			$(DRM_TOPDIR)/drm_crtc.c		\
52
			../ttm/ttm_tt.c				\
52
			$(DRM_TOPDIR)/drm_crtc_helper.c		\
53
			$(DRM_TOPDIR)/drm_cache.c		\
53
			$(DRM_TOPDIR)/drm_dp_helper.c		\
54
			$(DRM_TOPDIR)/drm_crtc.c		\
54
			$(DRM_TOPDIR)/drm_drv.c			\
55
			$(DRM_TOPDIR)/drm_crtc_helper.c		\
55
			$(DRM_TOPDIR)/drm_edid.c		\
56
			$(DRM_TOPDIR)/drm_dp_helper.c		\
56
			$(DRM_TOPDIR)/drm_fb_helper.c		\
57
			$(DRM_TOPDIR)/drm_drv.c			\
-
 
58
			$(DRM_TOPDIR)/drm_atomic.c		\
57
			$(DRM_TOPDIR)/drm_gem.c			\
59
			$(DRM_TOPDIR)/drm_edid.c		\
58
			$(DRM_TOPDIR)/drm_global.c		\
60
			$(DRM_TOPDIR)/drm_fb_helper.c		\
59
			$(DRM_TOPDIR)/drm_irq.c			\
61
			$(DRM_TOPDIR)/drm_gem.c			\
60
			$(DRM_TOPDIR)/drm_mm.c			\
62
			$(DRM_TOPDIR)/drm_global.c		\
61
			$(DRM_TOPDIR)/drm_modes.c		\
63
			$(DRM_TOPDIR)/drm_irq.c			\
62
			$(DRM_TOPDIR)/drm_modeset_lock.c	\
64
			$(DRM_TOPDIR)/drm_mm.c			\
63
			$(DRM_TOPDIR)/drm_pci.c			\
65
			$(DRM_TOPDIR)/drm_modes.c		\
64
			$(DRM_TOPDIR)/drm_plane_helper.c	\
66
			$(DRM_TOPDIR)/drm_modeset_lock.c	\
65
			$(DRM_TOPDIR)/drm_probe_helper.c	\
67
			$(DRM_TOPDIR)/drm_pci.c			\
66
			$(DRM_TOPDIR)/drm_rect.c		\
68
			$(DRM_TOPDIR)/drm_plane_helper.c	\
67
			$(DRM_TOPDIR)/drm_stub.c		\
69
			$(DRM_TOPDIR)/drm_probe_helper.c	\
68
			$(DRM_TOPDIR)/drm_vma_manager.c		\
70
			$(DRM_TOPDIR)/drm_rect.c		\
69
			$(DRM_TOPDIR)/i2c/i2c-core.c		\
71
			$(DRM_TOPDIR)/drm_stub.c		\
70
			$(DRM_TOPDIR)/i2c/i2c-algo-bit.c	\
72
			$(DRM_TOPDIR)/drm_vma_manager.c		\
71
			hmm.c					\
73
			$(DRM_TOPDIR)/i2c/i2c-core.c		\
72
			radeon_device.c				\
74
			$(DRM_TOPDIR)/i2c/i2c-algo-bit.c	\
73
			atom.c					\
75
			hmm.c					\
74
			atombios_crtc.c				\
76
			radeon_device.c				\
75
			atombios_dp.c				\
77
			atom.c					\
76
			atombios_encoders.c			\
78
			atombios_crtc.c				\
77
			atombios_i2c.c				\
79
			atombios_dp.c				\
78
			btc_dpm.c				\
80
			atombios_encoders.c			\
79
			cayman_blit_shaders.c			\
81
			atombios_i2c.c				\
80
			ci_dpm.c				\
82
			btc_dpm.c				\
81
			ci_smc.c				\
83
			cayman_blit_shaders.c			\
82
			cik.c					\
84
			ci_dpm.c				\
83
			cik_blit_shaders.c			\
85
			ci_smc.c				\
84
			cik_sdma.c				\
86
			cik.c					\
85
			cypress_dpm.c				\
87
			cik_blit_shaders.c			\
86
			dce3_1_afmt.c				\
88
			cik_sdma.c				\
87
			dce6_afmt.c				\
89
			cypress_dpm.c				\
88
			evergreen.c				\
90
			dce3_1_afmt.c				\
89
			evergreen_blit_shaders.c		\
91
			dce6_afmt.c				\
90
			evergreen_cs.c				\
92
			evergreen.c				\
91
			evergreen_dma.c				\
93
			evergreen_blit_shaders.c		\
92
			evergreen_hdmi.c			\
94
			evergreen_cs.c				\
93
			kv_dpm.c				\
95
			evergreen_dma.c				\
94
			kv_smc.c				\
96
			evergreen_hdmi.c			\
95
			ni.c					\
97
			kv_dpm.c				\
96
			ni_dma.c				\
98
			kv_smc.c				\
97
			ni_dpm.c				\
99
			ni.c					\
98
			radeon_agp.c				\
100
			ni_dma.c				\
99
			radeon_asic.c				\
101
			ni_dpm.c				\
100
			radeon_atombios.c			\
102
			radeon_agp.c				\
101
			radeon_benchmark.c			\
103
			radeon_asic.c				\
102
			radeon_bios.c				\
104
			radeon_atombios.c			\
103
			radeon_combios.c			\
105
			radeon_benchmark.c			\
104
			radeon_connectors.c			\
106
			radeon_bios.c				\
105
			radeon_cs.c				\
107
			radeon_combios.c			\
106
			radeon_clocks.c				\
108
			radeon_connectors.c			\
107
			radeon_display.c			\
109
			radeon_cs.c				\
108
			radeon_encoders.c			\
110
			radeon_clocks.c				\
109
			radeon_fence.c				\
111
			radeon_display.c			\
110
			radeon_fb.c				\
112
			radeon_encoders.c			\
111
			radeon_gart.c				\
113
			radeon_fence.c				\
112
			radeon_gem.c				\
114
			radeon_fb.c				\
113
			radeon_i2c.c				\
115
			radeon_gart.c				\
114
			radeon_ib.c				\
116
			radeon_gem.c				\
115
			radeon_irq_kms.c			\
117
			radeon_i2c.c				\
116
			radeon_legacy_crtc.c			\
118
			radeon_ib.c				\
117
			radeon_legacy_encoders.c		\
119
			radeon_irq_kms.c			\
118
			radeon_legacy_tv.c			\
120
			radeon_legacy_crtc.c			\
119
			radeon_object.c				\
121
			radeon_legacy_encoders.c		\
120
			radeon_pm.c				\
122
			radeon_legacy_tv.c			\
121
			radeon_ring.c				\
123
			radeon_object.c				\
122
			radeon_sa.c				\
124
			radeon_pm.c				\
123
			radeon_semaphore.c			\
125
			radeon_ring.c				\
124
			radeon_test.c				\
126
			radeon_sa.c				\
125
			radeon_ttm.c				\
127
			radeon_semaphore.c			\
-
 
128
			radeon_sync.c				\
126
			radeon_ucode.c				\
129
			radeon_test.c				\
127
			radeon_uvd.c				\
130
			radeon_ttm.c				\
128
			radeon_vce.c				\
131
			radeon_ucode.c				\
129
			radeon_vm.c				\
132
			radeon_uvd.c				\
130
			rdisplay_kms.c				\
133
			radeon_vce.c				\
131
			r100.c					\
134
			radeon_vm.c				\
132
			r200.c					\
135
			rdisplay_kms.c				\
133
			r300.c					\
136
			r100.c					\
134
			r420.c					\
137
			r200.c					\
135
			rv515.c					\
138
			r300.c					\
136
			rv730_dpm.c				\
139
			r420.c					\
137
			rv740_dpm.c				\
140
			rv515.c					\
138
			r520.c					\
141
			rv730_dpm.c				\
139
			r600.c					\
142
			rv740_dpm.c				\
140
			r600_audio.c				\
143
			r520.c					\
141
			r600_blit_shaders.c			\
144
			r600.c					\
142
			r600_cs.c				\
-
 
143
			r600_dma.c				\
145
			r600_blit_shaders.c			\
144
			r600_dpm.c				\
146
			r600_cs.c				\
145
			r600_hdmi.c				\
147
			r600_dma.c				\
146
			rs400.c					\
148
			r600_dpm.c				\
147
			rs600.c					\
149
			r600_hdmi.c				\
148
			rs690.c					\
150
			rs400.c					\
149
			rv6xx_dpm.c				\
151
			rs600.c					\
150
			rs780_dpm.c				\
152
			rs690.c					\
151
			rv770.c					\
153
			rv6xx_dpm.c				\
152
			rv770_dma.c				\
154
			rs780_dpm.c				\
153
			rv770_dpm.c				\
155
			rv770.c					\
154
			rv770_smc.c				\
156
			rv770_dma.c				\
155
			rdisplay.c				\
157
			rv770_dpm.c				\
156
			cmdline.c				\
158
			rv770_smc.c				\
157
			si.c					\
159
			rdisplay.c				\
158
			si_blit_shaders.c			\
160
			cmdline.c				\
159
			si_dma.c				\
161
			si.c					\
160
			si_dpm.c				\
162
			si_blit_shaders.c			\
161
			si_smc.c				\
163
			si_dma.c				\
162
			sumo_dpm.c				\
164
			si_dpm.c				\
163
			sumo_smc.c				\
165
			si_smc.c				\
164
			trinity_dpm.c				\
166
			sumo_dpm.c				\
165
			trinity_smc.c				\
167
			sumo_smc.c				\
166
			utils.c					\
168
			trinity_dpm.c				\
167
			uvd_v1_0.c				\
169
			trinity_smc.c				\
168
			uvd_v2_2.c				\
170
			utils.c					\
169
			uvd_v3_1.c				\
171
			uvd_v1_0.c				\
170
			uvd_v4_2.c				\
172
			uvd_v2_2.c				\
171
			vce_v1_0.c				\
173
			uvd_v3_1.c				\
172
			vce_v2_0.c				\
174
			uvd_v4_2.c				\
173
			fwblob.asm
175
			vce_v1_0.c				\
174
 
176
			vce_v2_0.c				\
175
FW_BINS=							\
177
			fwblob.asm
176
			firmware/R100_cp.bin			\
178
 
177
			firmware/R200_cp.bin			\
179
FW_BINS=							\
178
			firmware/R300_cp.bin			\
180
			firmware/R100_cp.bin			\
179
			firmware/R420_cp.bin			\
181
			firmware/R200_cp.bin			\
180
			firmware/R520_cp.bin			\
182
			firmware/R300_cp.bin			\
181
								\
183
			firmware/R420_cp.bin			\
182
			firmware/RS690_cp.bin			\
184
			firmware/R520_cp.bin			\
183
			firmware/RS600_cp.bin			\
185
								\
184
			firmware/RS780_me.bin			\
186
			firmware/RS690_cp.bin			\
185
			firmware/RS780_pfp.bin			\
187
			firmware/RS600_cp.bin			\
186
								\
188
			firmware/RS780_me.bin			\
187
			firmware/RV610_me.bin			\
189
			firmware/RS780_pfp.bin			\
188
			firmware/RV620_me.bin			\
190
								\
189
			firmware/RV630_me.bin			\
191
			firmware/RV610_me.bin			\
190
			firmware/RV635_me.bin			\
192
			firmware/RV620_me.bin			\
191
			firmware/RV670_me.bin			\
193
			firmware/RV630_me.bin			\
192
			firmware/RV710_me.bin			\
194
			firmware/RV635_me.bin			\
193
			firmware/RV730_me.bin			\
195
			firmware/RV670_me.bin			\
194
			firmware/RV770_me.bin			\
196
			firmware/RV710_me.bin			\
195
								\
197
			firmware/RV730_me.bin			\
196
			firmware/RV610_pfp.bin			\
198
			firmware/RV770_me.bin			\
197
			firmware/RV620_pfp.bin			\
199
								\
198
			firmware/RV630_pfp.bin			\
200
			firmware/RV610_pfp.bin			\
199
			firmware/RV635_pfp.bin			\
201
			firmware/RV620_pfp.bin			\
200
			firmware/RV670_pfp.bin			\
202
			firmware/RV630_pfp.bin			\
201
			firmware/RV710_pfp.bin			\
203
			firmware/RV635_pfp.bin			\
202
			firmware/RV730_pfp.bin			\
204
			firmware/RV670_pfp.bin			\
203
			firmware/RV770_pfp.bin			\
205
			firmware/RV710_pfp.bin			\
204
								\
206
			firmware/RV730_pfp.bin			\
205
			firmware/R600_rlc.bin			\
207
			firmware/RV770_pfp.bin			\
206
			firmware/R700_rlc.bin
208
								\
207
 
209
			firmware/R600_rlc.bin			\
208
 
210
			firmware/R700_rlc.bin
209
SRC_DEP:=    
211
 
210
 
212
 
211
 
213
SRC_DEP:=    
212
NAME_OBJS =  $(patsubst %.S, %.o, $(patsubst %.asm, %.o,\
214
 
213
            $(patsubst %.c, %.o, $(NAME_SRC))))
215
 
214
 
216
NAME_OBJS =  $(patsubst %.S, %.o, $(patsubst %.asm, %.o,\
215
 
217
            $(patsubst %.c, %.o, $(NAME_SRC))))
216
 
218
 
217
all: $(NAME).dll
219
 
218
 
220
 
219
$(NAME).dll: $(NAME_OBJS) $(FW_BINS) $(SRC_DEP) $(HFILES) $(LIBPATH)/libcore.a $(LIBPATH)/libddk.a atikms.lds Makefile
221
all: $(NAME).dll
220
	$(LD) -L$(LIBPATH) $(LDFLAGS) -T atikms.lds -o $@ $(NAME_OBJS) $(LIBS)  
222
 
221
 
223
$(NAME).dll: $(NAME_OBJS) $(FW_BINS) $(SRC_DEP) $(HFILES) $(LIBPATH)/libcore.a $(LIBPATH)/libddk.a atikms.lds Makefile
222
 
224
	$(LD) -L$(LIBPATH) $(LDFLAGS) -T atikms.lds -o $@ $(NAME_OBJS) $(LIBS)  
223
%.o : %.c $(HFILES) Makefile
225
 
224
	$(CC) $(CFLAGS) $(DEFINES) -o $@ $<
226
 
225
 
227
%.o : %.c $(HFILES) Makefile
226
%.o : %.S $(HFILES) Makefile
228
	$(CC) $(CFLAGS) $(DEFINES) -o $@ $<
227
	$(AS) -o $@ $<
229
 
228
 
230
%.o : %.S $(HFILES) Makefile
229
fwblob.o:  fwblob.asm $(FW_BINS) Makefile
231
	$(AS) -o $@ $<
230
	$(FASM) $< $@
232
 
231
 
233
fwblob.o:  fwblob.asm $(FW_BINS) Makefile
232
 
234
	$(FASM) $< $@
233
clean: 
235
 
234
	-rm -f */*.o
236
 
235
 
237
clean: 
236
fwblob.o:>
238
	-rm -f */*.o
237
 
239
 
238
%.o>
240
fwblob.o:>
-
 
241
 
-
 
242
%.o>