Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 234134
b: refs/heads/master
c: 52bd080
h: refs/heads/master
v: v3
  • Loading branch information
Thomas Gleixner authored and Ralf Baechle committed Mar 14, 2011
1 parent 4f8f08c commit 08a9522
Show file tree
Hide file tree
Showing 43 changed files with 156 additions and 274 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 869c34f5208adde010065c387354f2ebe4ec3bfc
refs/heads/master: 52bd080d5c87af556bf71e3b07bdd8586166c43b
4 changes: 2 additions & 2 deletions trunk/arch/mips/kernel/vpe.c
Original file line number Diff line number Diff line change
Expand Up @@ -148,9 +148,9 @@ struct {
spinlock_t tc_list_lock;
struct list_head tc_list; /* Thread contexts */
} vpecontrol = {
.vpe_list_lock = SPIN_LOCK_UNLOCKED,
.vpe_list_lock = __SPIN_LOCK_UNLOCKED(vpe_list_lock),
.vpe_list = LIST_HEAD_INIT(vpecontrol.vpe_list),
.tc_list_lock = SPIN_LOCK_UNLOCKED,
.tc_list_lock = __SPIN_LOCK_UNLOCKED(tc_list_lock),
.tc_list = LIST_HEAD_INIT(vpecontrol.tc_list)
};

Expand Down
6 changes: 0 additions & 6 deletions trunk/arch/x86/include/asm/ce4100.h

This file was deleted.

8 changes: 4 additions & 4 deletions trunk/arch/x86/kernel/check.c
Original file line number Diff line number Diff line change
Expand Up @@ -106,8 +106,8 @@ void __init setup_bios_corruption_check(void)
addr += size;
}

if (num_scan_areas)
printk(KERN_INFO "Scanning %d areas for low memory corruption\n", num_scan_areas);
printk(KERN_INFO "Scanning %d areas for low memory corruption\n",
num_scan_areas);
}


Expand Down Expand Up @@ -143,12 +143,12 @@ static void check_corruption(struct work_struct *dummy)
{
check_for_bios_corruption();
schedule_delayed_work(&bios_check_work,
round_jiffies_relative(corruption_check_period*HZ));
round_jiffies_relative(corruption_check_period*HZ));
}

static int start_periodic_check_for_corruption(void)
{
if (!num_scan_areas || !memory_corruption_check || corruption_check_period == 0)
if (!memory_corruption_check || corruption_check_period == 0)
return 0;

printk(KERN_INFO "Scanning for low memory corruption every %d seconds\n",
Expand Down
14 changes: 4 additions & 10 deletions trunk/arch/x86/mm/fault.c
Original file line number Diff line number Diff line change
Expand Up @@ -229,14 +229,15 @@ void vmalloc_sync_all(void)
for (address = VMALLOC_START & PMD_MASK;
address >= TASK_SIZE && address < FIXADDR_TOP;
address += PMD_SIZE) {

unsigned long flags;
struct page *page;

spin_lock(&pgd_lock);
spin_lock_irqsave(&pgd_lock, flags);
list_for_each_entry(page, &pgd_list, lru) {
spinlock_t *pgt_lock;
pmd_t *ret;

/* the pgt_lock only for Xen */
pgt_lock = &pgd_page_get_mm(page)->page_table_lock;

spin_lock(pgt_lock);
Expand All @@ -246,7 +247,7 @@ void vmalloc_sync_all(void)
if (!ret)
break;
}
spin_unlock(&pgd_lock);
spin_unlock_irqrestore(&pgd_lock, flags);
}
}

Expand Down Expand Up @@ -827,13 +828,6 @@ mm_fault_error(struct pt_regs *regs, unsigned long error_code,
unsigned long address, unsigned int fault)
{
if (fault & VM_FAULT_OOM) {
/* Kernel mode? Handle exceptions or die: */
if (!(error_code & PF_USER)) {
up_read(&current->mm->mmap_sem);
no_context(regs, error_code, address);
return;
}

out_of_memory(regs, error_code, address);
} else {
if (fault & (VM_FAULT_SIGBUS|VM_FAULT_HWPOISON|
Expand Down
6 changes: 3 additions & 3 deletions trunk/arch/x86/mm/init_64.c
Original file line number Diff line number Diff line change
Expand Up @@ -105,18 +105,18 @@ void sync_global_pgds(unsigned long start, unsigned long end)

for (address = start; address <= end; address += PGDIR_SIZE) {
const pgd_t *pgd_ref = pgd_offset_k(address);
unsigned long flags;
struct page *page;

if (pgd_none(*pgd_ref))
continue;

spin_lock(&pgd_lock);
spin_lock_irqsave(&pgd_lock, flags);
list_for_each_entry(page, &pgd_list, lru) {
pgd_t *pgd;
spinlock_t *pgt_lock;

pgd = (pgd_t *)page_address(page) + pgd_index(address);
/* the pgt_lock only for Xen */
pgt_lock = &pgd_page_get_mm(page)->page_table_lock;
spin_lock(pgt_lock);

Expand All @@ -128,7 +128,7 @@ void sync_global_pgds(unsigned long start, unsigned long end)

spin_unlock(pgt_lock);
}
spin_unlock(&pgd_lock);
spin_unlock_irqrestore(&pgd_lock, flags);
}
}

Expand Down
18 changes: 10 additions & 8 deletions trunk/arch/x86/mm/pageattr.c
Original file line number Diff line number Diff line change
Expand Up @@ -57,10 +57,12 @@ static unsigned long direct_pages_count[PG_LEVEL_NUM];

void update_page_count(int level, unsigned long pages)
{
unsigned long flags;

/* Protect against CPA */
spin_lock(&pgd_lock);
spin_lock_irqsave(&pgd_lock, flags);
direct_pages_count[level] += pages;
spin_unlock(&pgd_lock);
spin_unlock_irqrestore(&pgd_lock, flags);
}

static void split_page_count(int level)
Expand Down Expand Up @@ -392,7 +394,7 @@ static int
try_preserve_large_page(pte_t *kpte, unsigned long address,
struct cpa_data *cpa)
{
unsigned long nextpage_addr, numpages, pmask, psize, addr, pfn;
unsigned long nextpage_addr, numpages, pmask, psize, flags, addr, pfn;
pte_t new_pte, old_pte, *tmp;
pgprot_t old_prot, new_prot, req_prot;
int i, do_split = 1;
Expand All @@ -401,7 +403,7 @@ try_preserve_large_page(pte_t *kpte, unsigned long address,
if (cpa->force_split)
return 1;

spin_lock(&pgd_lock);
spin_lock_irqsave(&pgd_lock, flags);
/*
* Check for races, another CPU might have split this page
* up already:
Expand Down Expand Up @@ -496,14 +498,14 @@ try_preserve_large_page(pte_t *kpte, unsigned long address,
}

out_unlock:
spin_unlock(&pgd_lock);
spin_unlock_irqrestore(&pgd_lock, flags);

return do_split;
}

static int split_large_page(pte_t *kpte, unsigned long address)
{
unsigned long pfn, pfninc = 1;
unsigned long flags, pfn, pfninc = 1;
unsigned int i, level;
pte_t *pbase, *tmp;
pgprot_t ref_prot;
Expand All @@ -517,7 +519,7 @@ static int split_large_page(pte_t *kpte, unsigned long address)
if (!base)
return -ENOMEM;

spin_lock(&pgd_lock);
spin_lock_irqsave(&pgd_lock, flags);
/*
* Check for races, another CPU might have split this page
* up for us already:
Expand Down Expand Up @@ -589,7 +591,7 @@ static int split_large_page(pte_t *kpte, unsigned long address)
*/
if (base)
__free_page(base);
spin_unlock(&pgd_lock);
spin_unlock_irqrestore(&pgd_lock, flags);

return 0;
}
Expand Down
11 changes: 7 additions & 4 deletions trunk/arch/x86/mm/pgtable.c
Original file line number Diff line number Diff line change
Expand Up @@ -121,12 +121,14 @@ static void pgd_ctor(struct mm_struct *mm, pgd_t *pgd)

static void pgd_dtor(pgd_t *pgd)
{
unsigned long flags; /* can be called from interrupt context */

if (SHARED_KERNEL_PMD)
return;

spin_lock(&pgd_lock);
spin_lock_irqsave(&pgd_lock, flags);
pgd_list_del(pgd);
spin_unlock(&pgd_lock);
spin_unlock_irqrestore(&pgd_lock, flags);
}

/*
Expand Down Expand Up @@ -258,6 +260,7 @@ pgd_t *pgd_alloc(struct mm_struct *mm)
{
pgd_t *pgd;
pmd_t *pmds[PREALLOCATED_PMDS];
unsigned long flags;

pgd = (pgd_t *)__get_free_page(PGALLOC_GFP);

Expand All @@ -277,12 +280,12 @@ pgd_t *pgd_alloc(struct mm_struct *mm)
* respect to anything walking the pgd_list, so that they
* never see a partially populated pgd.
*/
spin_lock(&pgd_lock);
spin_lock_irqsave(&pgd_lock, flags);

pgd_ctor(mm, pgd);
pgd_prepopulate_pmd(mm, pgd, pmds);

spin_unlock(&pgd_lock);
spin_unlock_irqrestore(&pgd_lock, flags);

return pgd;

Expand Down
7 changes: 3 additions & 4 deletions trunk/arch/x86/pci/ce4100.c
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,6 @@
#include <linux/pci.h>
#include <linux/init.h>

#include <asm/ce4100.h>
#include <asm/pci_x86.h>

struct sim_reg {
Expand Down Expand Up @@ -307,10 +306,10 @@ struct pci_raw_ops ce4100_pci_conf = {
.write = ce4100_conf_write,
};

int __init ce4100_pci_init(void)
static int __init ce4100_pci_init(void)
{
init_sim_regs();
raw_pci_ops = &ce4100_pci_conf;
/* Indicate caller that it should invoke pci_legacy_init() */
return 1;
return 0;
}
subsys_initcall(ce4100_pci_init);
2 changes: 0 additions & 2 deletions trunk/arch/x86/platform/ce4100/ce4100.c
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
#include <linux/serial_reg.h>
#include <linux/serial_8250.h>

#include <asm/ce4100.h>
#include <asm/setup.h>
#include <asm/io.h>

Expand Down Expand Up @@ -130,5 +129,4 @@ void __init x86_ce4100_early_setup(void)
x86_init.resources.probe_roms = x86_init_noop;
x86_init.mpparse.get_smp_config = x86_init_uint_noop;
x86_init.mpparse.find_smp_config = sdv_find_smp_config;
x86_init.pci.init = ce4100_pci_init;
}
10 changes: 6 additions & 4 deletions trunk/arch/x86/xen/mmu.c
Original file line number Diff line number Diff line change
Expand Up @@ -986,9 +986,10 @@ static void xen_pgd_pin(struct mm_struct *mm)
*/
void xen_mm_pin_all(void)
{
unsigned long flags;
struct page *page;

spin_lock(&pgd_lock);
spin_lock_irqsave(&pgd_lock, flags);

list_for_each_entry(page, &pgd_list, lru) {
if (!PagePinned(page)) {
Expand All @@ -997,7 +998,7 @@ void xen_mm_pin_all(void)
}
}

spin_unlock(&pgd_lock);
spin_unlock_irqrestore(&pgd_lock, flags);
}

/*
Expand Down Expand Up @@ -1098,9 +1099,10 @@ static void xen_pgd_unpin(struct mm_struct *mm)
*/
void xen_mm_unpin_all(void)
{
unsigned long flags;
struct page *page;

spin_lock(&pgd_lock);
spin_lock_irqsave(&pgd_lock, flags);

list_for_each_entry(page, &pgd_list, lru) {
if (PageSavePinned(page)) {
Expand All @@ -1110,7 +1112,7 @@ void xen_mm_unpin_all(void)
}
}

spin_unlock(&pgd_lock);
spin_unlock_irqrestore(&pgd_lock, flags);
}

void xen_activate_mm(struct mm_struct *prev, struct mm_struct *next)
Expand Down
3 changes: 2 additions & 1 deletion trunk/drivers/gpu/drm/radeon/evergreen.c
Original file line number Diff line number Diff line change
Expand Up @@ -2194,6 +2194,7 @@ int evergreen_mc_init(struct radeon_device *rdev)
rdev->mc.real_vram_size = RREG32(CONFIG_MEMSIZE) * 1024 * 1024;
}
rdev->mc.visible_vram_size = rdev->mc.aper_size;
rdev->mc.active_vram_size = rdev->mc.visible_vram_size;
r700_vram_gtt_location(rdev, &rdev->mc);
radeon_update_bandwidth_info(rdev);

Expand Down Expand Up @@ -2933,7 +2934,7 @@ static int evergreen_startup(struct radeon_device *rdev)
/* XXX: ontario has problems blitting to gart at the moment */
if (rdev->family == CHIP_PALM) {
rdev->asic->copy = NULL;
radeon_ttm_set_active_vram_size(rdev, rdev->mc.visible_vram_size);
rdev->mc.active_vram_size = rdev->mc.visible_vram_size;
}

/* allocate wb buffer */
Expand Down
4 changes: 2 additions & 2 deletions trunk/drivers/gpu/drm/radeon/evergreen_blit_kms.c
Original file line number Diff line number Diff line change
Expand Up @@ -623,15 +623,15 @@ int evergreen_blit_init(struct radeon_device *rdev)
dev_err(rdev->dev, "(%d) pin blit object failed\n", r);
return r;
}
radeon_ttm_set_active_vram_size(rdev, rdev->mc.real_vram_size);
rdev->mc.active_vram_size = rdev->mc.real_vram_size;
return 0;
}

void evergreen_blit_fini(struct radeon_device *rdev)
{
int r;

radeon_ttm_set_active_vram_size(rdev, rdev->mc.visible_vram_size);
rdev->mc.active_vram_size = rdev->mc.visible_vram_size;
if (rdev->r600_blit.shader_obj == NULL)
return;
/* If we can't reserve the bo, unref should be enough to destroy
Expand Down
5 changes: 3 additions & 2 deletions trunk/drivers/gpu/drm/radeon/r100.c
Original file line number Diff line number Diff line change
Expand Up @@ -1024,7 +1024,7 @@ int r100_cp_init(struct radeon_device *rdev, unsigned ring_size)
return r;
}
rdev->cp.ready = true;
radeon_ttm_set_active_vram_size(rdev, rdev->mc.real_vram_size);
rdev->mc.active_vram_size = rdev->mc.real_vram_size;
return 0;
}

Expand All @@ -1042,7 +1042,7 @@ void r100_cp_fini(struct radeon_device *rdev)
void r100_cp_disable(struct radeon_device *rdev)
{
/* Disable ring */
radeon_ttm_set_active_vram_size(rdev, rdev->mc.visible_vram_size);
rdev->mc.active_vram_size = rdev->mc.visible_vram_size;
rdev->cp.ready = false;
WREG32(RADEON_CP_CSQ_MODE, 0);
WREG32(RADEON_CP_CSQ_CNTL, 0);
Expand Down Expand Up @@ -2312,6 +2312,7 @@ void r100_vram_init_sizes(struct radeon_device *rdev)
/* FIXME we don't use the second aperture yet when we could use it */
if (rdev->mc.visible_vram_size > rdev->mc.aper_size)
rdev->mc.visible_vram_size = rdev->mc.aper_size;
rdev->mc.active_vram_size = rdev->mc.visible_vram_size;
config_aper_size = RREG32(RADEON_CONFIG_APER_SIZE);
if (rdev->flags & RADEON_IS_IGP) {
uint32_t tom;
Expand Down
3 changes: 2 additions & 1 deletion trunk/drivers/gpu/drm/radeon/r600.c
Original file line number Diff line number Diff line change
Expand Up @@ -1255,6 +1255,7 @@ int r600_mc_init(struct radeon_device *rdev)
rdev->mc.mc_vram_size = RREG32(CONFIG_MEMSIZE);
rdev->mc.real_vram_size = RREG32(CONFIG_MEMSIZE);
rdev->mc.visible_vram_size = rdev->mc.aper_size;
rdev->mc.active_vram_size = rdev->mc.visible_vram_size;
r600_vram_gtt_location(rdev, &rdev->mc);

if (rdev->flags & RADEON_IS_IGP) {
Expand Down Expand Up @@ -1936,7 +1937,7 @@ void r600_pciep_wreg(struct radeon_device *rdev, u32 reg, u32 v)
*/
void r600_cp_stop(struct radeon_device *rdev)
{
radeon_ttm_set_active_vram_size(rdev, rdev->mc.visible_vram_size);
rdev->mc.active_vram_size = rdev->mc.visible_vram_size;
WREG32(R_0086D8_CP_ME_CNTL, S_0086D8_CP_ME_HALT(1));
WREG32(SCRATCH_UMSK, 0);
}
Expand Down
Loading

0 comments on commit 08a9522

Please sign in to comment.