Commit abe1ee3a authored by Tim Abbott's avatar Tim Abbott Committed by Sam Ravnborg

Use macros for .data.page_aligned section.

This patch changes the remaining direct references to
.data.page_aligned in C and assembly code to use the macros in
include/linux/linkage.h.
Signed-off-by: default avatarTim Abbott <tabbott@ksplice.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Haavard Skinnemoen <hskinnemoen@atmel.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: default avatarSam Ravnborg <sam@ravnborg.org>
parent 02b7da37
...@@ -24,11 +24,9 @@ ...@@ -24,11 +24,9 @@
#include <asm/setup.h> #include <asm/setup.h>
#include <asm/sections.h> #include <asm/sections.h>
#define __page_aligned __attribute__((section(".data.page_aligned")))
DEFINE_PER_CPU(struct mmu_gather, mmu_gathers); DEFINE_PER_CPU(struct mmu_gather, mmu_gathers);
pgd_t swapper_pg_dir[PTRS_PER_PGD] __page_aligned; pgd_t swapper_pg_dir[PTRS_PER_PGD] __page_aligned_data;
struct page *empty_zero_page; struct page *empty_zero_page;
EXPORT_SYMBOL(empty_zero_page); EXPORT_SYMBOL(empty_zero_page);
......
/* /*
* Copyright (C) 2004 Benjamin Herrenschmidt, IBM Corp. * Copyright (C) 2004 Benjamin Herrenschmidt, IBM Corp.
* <benh@kernel.crashing.org> * <benh@kernel.crashing.org>
...@@ -74,7 +75,7 @@ static int vdso_ready; ...@@ -74,7 +75,7 @@ static int vdso_ready;
static union { static union {
struct vdso_data data; struct vdso_data data;
u8 page[PAGE_SIZE]; u8 page[PAGE_SIZE];
} vdso_data_store __attribute__((__section__(".data.page_aligned"))); } vdso_data_store __page_aligned_data;
struct vdso_data *vdso_data = &vdso_data_store.data; struct vdso_data *vdso_data = &vdso_data_store.data;
/* Format of the patch table */ /* Format of the patch table */
......
#include <linux/init.h> #include <linux/init.h>
#include <linux/linkage.h>
#include <asm/page.h> #include <asm/page.h>
.section ".data.page_aligned" __PAGE_ALIGNED_DATA
.globl vdso32_start, vdso32_end .globl vdso32_start, vdso32_end
.balign PAGE_SIZE .balign PAGE_SIZE
......
#include <linux/init.h> #include <linux/init.h>
#include <linux/linkage.h>
#include <asm/page.h> #include <asm/page.h>
.section ".data.page_aligned" __PAGE_ALIGNED_DATA
.globl vdso64_start, vdso64_end .globl vdso64_start, vdso64_end
.balign PAGE_SIZE .balign PAGE_SIZE
......
...@@ -75,7 +75,7 @@ __setup("vdso=", vdso_setup); ...@@ -75,7 +75,7 @@ __setup("vdso=", vdso_setup);
static union { static union {
struct vdso_data data; struct vdso_data data;
u8 page[PAGE_SIZE]; u8 page[PAGE_SIZE];
} vdso_data_store __attribute__((__section__(".data.page_aligned"))); } vdso_data_store __page_aligned_data;
struct vdso_data *vdso_data = &vdso_data_store.data; struct vdso_data *vdso_data = &vdso_data_store.data;
/* /*
......
#include <linux/init.h> #include <linux/init.h>
#include <linux/linkage.h>
#include <asm/page.h> #include <asm/page.h>
.section ".data.page_aligned" __PAGE_ALIGNED_DATA
.globl vdso32_start, vdso32_end .globl vdso32_start, vdso32_end
.balign PAGE_SIZE .balign PAGE_SIZE
......
#include <linux/init.h> #include <linux/init.h>
#include <linux/linkage.h>
#include <asm/page.h> #include <asm/page.h>
.section ".data.page_aligned" __PAGE_ALIGNED_DATA
.globl vdso64_start, vdso64_end .globl vdso64_start, vdso64_end
.balign PAGE_SIZE .balign PAGE_SIZE
......
#ifndef _ASM_X86_CACHE_H #ifndef _ASM_X86_CACHE_H
#define _ASM_X86_CACHE_H #define _ASM_X86_CACHE_H
#include <linux/linkage.h>
/* L1 cache line size */ /* L1 cache line size */
#define L1_CACHE_SHIFT (CONFIG_X86_L1_CACHE_SHIFT) #define L1_CACHE_SHIFT (CONFIG_X86_L1_CACHE_SHIFT)
#define L1_CACHE_BYTES (1 << L1_CACHE_SHIFT) #define L1_CACHE_BYTES (1 << L1_CACHE_SHIFT)
...@@ -13,7 +15,7 @@ ...@@ -13,7 +15,7 @@
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
#define __cacheline_aligned_in_smp \ #define __cacheline_aligned_in_smp \
__attribute__((__aligned__(1 << (INTERNODE_CACHE_SHIFT)))) \ __attribute__((__aligned__(1 << (INTERNODE_CACHE_SHIFT)))) \
__attribute__((__section__(".data.page_aligned"))) __page_aligned_data
#endif #endif
#endif #endif
......
...@@ -626,7 +626,7 @@ ENTRY(empty_zero_page) ...@@ -626,7 +626,7 @@ ENTRY(empty_zero_page)
* This starts the data section. * This starts the data section.
*/ */
#ifdef CONFIG_X86_PAE #ifdef CONFIG_X86_PAE
.section ".data.page_aligned","wa" __PAGE_ALIGNED_DATA
/* Page-aligned for the benefit of paravirt? */ /* Page-aligned for the benefit of paravirt? */
.align PAGE_SIZE_asm .align PAGE_SIZE_asm
ENTRY(swapper_pg_dir) ENTRY(swapper_pg_dir)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment