mirror of
https://github.com/AtlasLinux/linux.git
synced 2026-02-02 15:22:09 -08:00
Change table chaining layout
Change the page member of the scatterlist structure to be an unsigned long, and encode more stuff in the lower bits: - Bits 0 and 1 zero: this is a normal sg entry. Next sg entry is located at sg + 1. - Bit 0 set: this is a chain entry, the next real entry is at ->page_link with the two low bits masked off. - Bit 1 set: this is the final entry in the sg entry. sg_next() will return NULL when passed such an entry. It's thus important that sg table users use the proper accessors to get and set the page member. Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
This commit is contained in:
@@ -5,7 +5,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
|
||||
unsigned int length;
|
||||
|
||||
@@ -5,7 +5,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page; /* buffer page */
|
||||
unsigned long page_link;
|
||||
unsigned int offset; /* buffer offset */
|
||||
dma_addr_t dma_address; /* dma address */
|
||||
unsigned int length; /* length */
|
||||
|
||||
@@ -4,7 +4,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
dma_addr_t dma_address;
|
||||
unsigned int length;
|
||||
|
||||
@@ -4,7 +4,7 @@
|
||||
#include <linux/mm.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
dma_addr_t dma_address;
|
||||
unsigned int length;
|
||||
|
||||
@@ -6,7 +6,7 @@ struct scatterlist {
|
||||
unsigned int length;
|
||||
|
||||
/* The following is i386 highmem junk - not used by us */
|
||||
struct page * page; /* Location for highmem page, if any */
|
||||
unsigned long page_link;
|
||||
unsigned int offset;/* for highmem, page offset */
|
||||
|
||||
};
|
||||
|
||||
@@ -22,7 +22,7 @@
|
||||
* and that's it. There's no excuse for not highmem enabling YOUR driver. /jens
|
||||
*/
|
||||
struct scatterlist {
|
||||
struct page *page; /* Location for highmem page, if any */
|
||||
unsigned long page_link;
|
||||
unsigned int offset; /* for highmem, page offset */
|
||||
|
||||
dma_addr_t dma_address;
|
||||
|
||||
@@ -4,7 +4,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
dma_addr_t dma_address;
|
||||
unsigned int length;
|
||||
|
||||
@@ -9,7 +9,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
unsigned int length; /* buffer length */
|
||||
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
struct scatterlist {
|
||||
char * address; /* Location data is to be transferred to, NULL for
|
||||
* highmem page */
|
||||
struct page * page; /* Location for highmem page, if any */
|
||||
unsigned long page_link;
|
||||
unsigned int offset;/* for highmem, page offset */
|
||||
|
||||
dma_addr_t dma_address;
|
||||
|
||||
@@ -4,7 +4,7 @@
|
||||
#include <linux/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
unsigned int length;
|
||||
|
||||
|
||||
@@ -5,7 +5,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
dma_addr_t dma_address;
|
||||
unsigned int length;
|
||||
|
||||
@@ -4,7 +4,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page * page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
dma_addr_t dma_address;
|
||||
unsigned int length;
|
||||
|
||||
@@ -5,7 +5,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
|
||||
unsigned int length;
|
||||
|
||||
@@ -14,7 +14,7 @@
|
||||
#include <asm/dma.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
unsigned int length;
|
||||
|
||||
|
||||
@@ -2,7 +2,7 @@
|
||||
#define _ASMS390_SCATTERLIST_H
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
unsigned int length;
|
||||
};
|
||||
|
||||
@@ -4,7 +4,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page * page; /* Location for highmem page, if any */
|
||||
unsigned long page_link;
|
||||
unsigned int offset;/* for highmem, page offset */
|
||||
dma_addr_t dma_address;
|
||||
unsigned int length;
|
||||
|
||||
@@ -14,7 +14,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page * page; /* Location for highmem page, if any */
|
||||
unsigned long page_link;
|
||||
unsigned int offset;/* for highmem, page offset */
|
||||
dma_addr_t dma_address;
|
||||
unsigned int length;
|
||||
|
||||
@@ -5,7 +5,7 @@
|
||||
#include <linux/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
|
||||
unsigned int length;
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned int offset;
|
||||
|
||||
unsigned int length;
|
||||
|
||||
@@ -17,7 +17,7 @@
|
||||
#include <asm/types.h>
|
||||
|
||||
struct scatterlist {
|
||||
struct page *page;
|
||||
unsigned long page_link;
|
||||
unsigned offset;
|
||||
dma_addr_t dma_address;
|
||||
unsigned length;
|
||||
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user