I am writing my own procfs read write handler.
static ssize_t mywrite(struct file *file, const char __user *ubuf, size_t count, loff_t *ppos) 
{
    printk(KERN_ALERT "write handler\n");
    int num,c,i,m;
    char buf[BUFSIZE];
    if(*ppos > 0 || count > BUFSIZE){
        printk(KERN_ALERT "failed *ppos > 0 || count > BUFSIZE");
        return -EFAULT;
    }
    if(copy_from_user(buf, ubuf, count)){
        printk(KERN_ALERT "FAILED copy_from_user(buf, ubuf, count)");
        return -EFAULT;
    }
    int characters_in_input = strlen(buf);
    printk(KERN_INFO "wrote %s in file and it's length is %d \n",buf,characters_in_input);
    return characters_in_input;
}
 
static ssize_t myread(struct file *file, char __user *ubuf,size_t count, loff_t *ppos) 
{
    some logic
}
    static struct file_operations myops = 
    {
        .owner = THIS_MODULE,
        .read = myread,
        .write = mywrite,
    };
 
static int simple_init(void)
{
    ent=proc_create("mydev",0777,NULL,&myops);
    printk(KERN_ALERT "hello...\n");
    return 0;}
And when I write smth from c code like
int fd = open("/proc/mydev", O_RDWR);
lseek(fd, 0 , SEEK_SET);
if(write(fd, "1", 10)==-1){
    printf("write failed");
};
handler output is "wrote 1 in file and it's length is 1 " but if I use bash and execute
echo "asd" > /proc/mydev
handler output is "wrote asd
\xa8B\x99ٚ\xff\xff\xa6\xb9\xff\xff\xff\xff辠Z\xb2\xff\xff in file and it's length is 28 "

printf("%s", "abc\n")doesn't output the NUL that is there, neither does bash'secho