Commit e24c22ad authored by Linus Torvalds's avatar Linus Torvalds

Merge bk://gkernel.bkbits.net/libata-2.6

into ppc970.osdl.org:/home/torvalds/v2.6/linux
parents d66bf085 c4d5e6fd
...@@ -107,8 +107,11 @@ pte_t *pte_alloc_one_kernel(struct mm_struct *mm, unsigned long address) ...@@ -107,8 +107,11 @@ pte_t *pte_alloc_one_kernel(struct mm_struct *mm, unsigned long address)
ptepage->mapping = (void *) mm; ptepage->mapping = (void *) mm;
ptepage->index = address & PMD_MASK; ptepage->index = address & PMD_MASK;
} }
} else } else {
pte = (pte_t *)early_get_page(); pte = (pte_t *)early_get_page();
if (pte)
clear_page(pte);
}
return pte; return pte;
} }
......
...@@ -62,7 +62,7 @@ void flush_hash_one_pte(pte_t *ptep) ...@@ -62,7 +62,7 @@ void flush_hash_one_pte(pte_t *ptep)
ptepage = virt_to_page(ptep); ptepage = virt_to_page(ptep);
mm = (struct mm_struct *) ptepage->mapping; mm = (struct mm_struct *) ptepage->mapping;
ptephys = __pa(ptep) & PAGE_MASK; ptephys = __pa(ptep) & PAGE_MASK;
addr = ptepage->index + (((unsigned long)ptep & ~PAGE_MASK) << 9); addr = ptepage->index + (((unsigned long)ptep & ~PAGE_MASK) << 10);
flush_hash_pages(mm->context, addr, ptephys, 1); flush_hash_pages(mm->context, addr, ptephys, 1);
} }
......
...@@ -628,11 +628,13 @@ int xmon_fault_handler(struct pt_regs *regs) ...@@ -628,11 +628,13 @@ int xmon_fault_handler(struct pt_regs *regs)
(data address breakpoint register) directly. */ (data address breakpoint register) directly. */
static void set_controlled_dabr(unsigned long val) static void set_controlled_dabr(unsigned long val)
{ {
#ifdef CONFIG_PPC_PSERIES
if (systemcfg->platform == PLATFORM_PSERIES_LPAR) { if (systemcfg->platform == PLATFORM_PSERIES_LPAR) {
int rc = plpar_hcall_norets(H_SET_DABR, val); int rc = plpar_hcall_norets(H_SET_DABR, val);
if (rc != H_Success) if (rc != H_Success)
xmon_printf("Warning: setting DABR failed (%d)\n", rc); xmon_printf("Warning: setting DABR failed (%d)\n", rc);
} else } else
#endif
set_dabr(val); set_dabr(val);
} }
......
...@@ -34,7 +34,7 @@ struct alps_model_info { ...@@ -34,7 +34,7 @@ struct alps_model_info {
unsigned char signature[3]; unsigned char signature[3];
unsigned char model; unsigned char model;
} alps_model_data[] = { } alps_model_data[] = {
{ { 0x33, 0x02, 0x0a }, ALPS_MODEL_GLIDEPOINT }, /* { { 0x33, 0x02, 0x0a }, ALPS_MODEL_GLIDEPOINT }, */
{ { 0x53, 0x02, 0x0a }, ALPS_MODEL_GLIDEPOINT }, { { 0x53, 0x02, 0x0a }, ALPS_MODEL_GLIDEPOINT },
{ { 0x53, 0x02, 0x14 }, ALPS_MODEL_GLIDEPOINT }, { { 0x53, 0x02, 0x14 }, ALPS_MODEL_GLIDEPOINT },
{ { 0x63, 0x02, 0x0a }, ALPS_MODEL_GLIDEPOINT }, { { 0x63, 0x02, 0x0a }, ALPS_MODEL_GLIDEPOINT },
...@@ -42,8 +42,8 @@ struct alps_model_info { ...@@ -42,8 +42,8 @@ struct alps_model_info {
{ { 0x73, 0x02, 0x0a }, ALPS_MODEL_GLIDEPOINT }, { { 0x73, 0x02, 0x0a }, ALPS_MODEL_GLIDEPOINT },
{ { 0x73, 0x02, 0x14 }, ALPS_MODEL_GLIDEPOINT }, { { 0x73, 0x02, 0x14 }, ALPS_MODEL_GLIDEPOINT },
{ { 0x63, 0x02, 0x28 }, ALPS_MODEL_GLIDEPOINT }, { { 0x63, 0x02, 0x28 }, ALPS_MODEL_GLIDEPOINT },
{ { 0x63, 0x02, 0x3c }, ALPS_MODEL_GLIDEPOINT }, /* { { 0x63, 0x02, 0x3c }, ALPS_MODEL_GLIDEPOINT }, */
{ { 0x63, 0x02, 0x50 }, ALPS_MODEL_GLIDEPOINT }, /* { { 0x63, 0x02, 0x50 }, ALPS_MODEL_GLIDEPOINT }, */
{ { 0x63, 0x02, 0x64 }, ALPS_MODEL_GLIDEPOINT }, { { 0x63, 0x02, 0x64 }, ALPS_MODEL_GLIDEPOINT },
{ { 0x20, 0x02, 0x0e }, ALPS_MODEL_DUALPOINT }, { { 0x20, 0x02, 0x0e }, ALPS_MODEL_DUALPOINT },
{ { 0x22, 0x02, 0x0a }, ALPS_MODEL_DUALPOINT }, { { 0x22, 0x02, 0x0a }, ALPS_MODEL_DUALPOINT },
......
...@@ -253,9 +253,9 @@ static struct region *__rh_alloc(struct region_hash *rh, region_t region) ...@@ -253,9 +253,9 @@ static struct region *__rh_alloc(struct region_hash *rh, region_t region)
else { else {
__rh_insert(rh, nreg); __rh_insert(rh, nreg);
if (nreg->state == RH_CLEAN) { if (nreg->state == RH_CLEAN) {
spin_lock_irq(&rh->region_lock); spin_lock(&rh->region_lock);
list_add(&nreg->list, &rh->clean_regions); list_add(&nreg->list, &rh->clean_regions);
spin_unlock_irq(&rh->region_lock); spin_unlock(&rh->region_lock);
} }
reg = nreg; reg = nreg;
} }
......
...@@ -303,10 +303,10 @@ static int do_getlk(struct file *filp, int cmd, struct file_lock *fl) ...@@ -303,10 +303,10 @@ static int do_getlk(struct file *filp, int cmd, struct file_lock *fl)
status = NFS_PROTO(inode)->lock(filp, cmd, fl); status = NFS_PROTO(inode)->lock(filp, cmd, fl);
else { else {
struct file_lock *cfl = posix_test_lock(filp, fl); struct file_lock *cfl = posix_test_lock(filp, fl);
if (cfl != NULL) {
fl->fl_type = F_UNLCK;
if (cfl != NULL)
memcpy(fl, cfl, sizeof(*fl)); memcpy(fl, cfl, sizeof(*fl));
fl->fl_type = F_UNLCK;
}
} }
unlock_kernel(); unlock_kernel();
return status; return status;
......
...@@ -54,7 +54,7 @@ struct agp_kern_info { ...@@ -54,7 +54,7 @@ struct agp_kern_info {
struct pci_dev *device; struct pci_dev *device;
enum chipset_type chipset; enum chipset_type chipset;
unsigned long mode; unsigned long mode;
off_t aper_base; unsigned long aper_base;
size_t aper_size; size_t aper_size;
int max_memory; /* In pages */ int max_memory; /* In pages */
int current_memory; int current_memory;
......
...@@ -64,7 +64,7 @@ typedef struct _agp_info { ...@@ -64,7 +64,7 @@ typedef struct _agp_info {
struct agp_version version; /* version of the driver */ struct agp_version version; /* version of the driver */
__u32 bridge_id; /* bridge vendor/device */ __u32 bridge_id; /* bridge vendor/device */
__u32 agp_mode; /* mode info of bridge */ __u32 agp_mode; /* mode info of bridge */
off_t aper_base; /* base of aperture */ unsigned long aper_base;/* base of aperture */
size_t aper_size; /* size of aperture */ size_t aper_size; /* size of aperture */
size_t pg_total; /* max pages (swap + system) */ size_t pg_total; /* max pages (swap + system) */
size_t pg_system; /* max pages (system) */ size_t pg_system; /* max pages (system) */
...@@ -118,7 +118,7 @@ struct agp_info { ...@@ -118,7 +118,7 @@ struct agp_info {
struct agp_version version; /* version of the driver */ struct agp_version version; /* version of the driver */
u32 bridge_id; /* bridge vendor/device */ u32 bridge_id; /* bridge vendor/device */
u32 agp_mode; /* mode info of bridge */ u32 agp_mode; /* mode info of bridge */
off_t aper_base; /* base of aperture */ unsigned long aper_base;/* base of aperture */
size_t aper_size; /* size of aperture */ size_t aper_size; /* size of aperture */
size_t pg_total; /* max pages (swap + system) */ size_t pg_total; /* max pages (swap + system) */
size_t pg_system; /* max pages (system) */ size_t pg_system; /* max pages (system) */
......
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