47a18c42d9
This is a test utility to verify ION buffer sharing in user space between 2 independent processes. It uses unix domain socket (with SCM_RIGHTS) as IPC to transfer an FD to another process to share the same buffer. This utility demonstrates how ION buffer sharing can be implemented between two user space processes, using various heap types. This utility is made to be run as part of kselftest framework in kernel. The utility is verified on Ubuntu-32 bit system with Linux Kernel 4.14, using ION system heap. For more information about the utility please check the README file. Signed-off-by: Pintu Agarwal <pintu.ping@gmail.com> Signed-off-by: Shuah Khan <shuahkh@osg.samsung.com>
56 lines
1.4 KiB
C
56 lines
1.4 KiB
C
#ifndef __ION_UTILS_H
|
|
#define __ION_UTILS_H
|
|
|
|
#include "ion.h"
|
|
|
|
#define SOCKET_NAME "ion_socket"
|
|
#define ION_DEVICE "/dev/ion"
|
|
|
|
#define ION_BUFFER_LEN 4096
|
|
#define MAX_HEAP_COUNT ION_HEAP_TYPE_CUSTOM
|
|
|
|
struct socket_info {
|
|
int sockfd;
|
|
int datafd;
|
|
unsigned long buflen;
|
|
};
|
|
|
|
struct ion_buffer_info {
|
|
int ionfd;
|
|
int buffd;
|
|
unsigned int heap_type;
|
|
unsigned int flag_type;
|
|
unsigned long heap_size;
|
|
unsigned long buflen;
|
|
unsigned char *buffer;
|
|
};
|
|
|
|
|
|
/* This is used to fill the data into the mapped buffer */
|
|
void write_buffer(void *buffer, unsigned long len);
|
|
|
|
/* This is used to read the data from the exported buffer */
|
|
void read_buffer(void *buffer, unsigned long len);
|
|
|
|
/* This is used to create an ION buffer FD for the kernel buffer
|
|
* So you can export this same buffer to others in the form of FD
|
|
*/
|
|
int ion_export_buffer_fd(struct ion_buffer_info *ion_info);
|
|
|
|
/* This is used to import or map an exported FD.
|
|
* So we point to same buffer without making a copy. Hence zero-copy.
|
|
*/
|
|
int ion_import_buffer_fd(struct ion_buffer_info *ion_info);
|
|
|
|
/* This is used to close all references for the ION client */
|
|
void ion_close_buffer_fd(struct ion_buffer_info *ion_info);
|
|
|
|
/* This is used to send FD to another process using socket IPC */
|
|
int socket_send_fd(struct socket_info *skinfo);
|
|
|
|
/* This is used to receive FD from another process using socket IPC */
|
|
int socket_receive_fd(struct socket_info *skinfo);
|
|
|
|
|
|
#endif
|