lwp_args.h 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /*
  2. * Copyright (c) 2006-2025 RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2024-01-12 Shell separate argv, envp, aux processing from execve(2).
  9. * Bugs fix for script arguments processing.
  10. */
  11. #ifndef __LWP_ARGV_H__
  12. #define __LWP_ARGV_H__
  13. #include <rtthread.h>
  14. struct rt_lwp;
  15. /**
  16. * @brief Type of arguments
  17. */
  18. enum lwp_args_type {
  19. LWP_ARGS_TYPE_ARG, /**< User-space arguments */
  20. LWP_ARGS_TYPE_KARG, /**< Kernel-space arguments */
  21. LWP_ARGS_TYPE_ENVP, /**< User-space environment variables */
  22. LWP_ARGS_TYPE_KENVP, /**< Kernel-space environment variables */
  23. LWP_ARGS_TYPE_NULLPTR /**< NULL pointer terminator */
  24. };
  25. /**
  26. * @brief String vector structure
  27. */
  28. struct lwp_string_vector
  29. {
  30. const char **strvec; /**< Pointer to array of strings */
  31. rt_uint32_t strvec_buflen; /**< Total buffer length of strvec */
  32. rt_uint32_t string_count; /**< Number of strings in strvec */
  33. };
  34. /**
  35. * @brief Arguments information structure
  36. *
  37. * @note str_buf stores all argument strings' content.
  38. * argv stores argument strings' pointers in str_buf.
  39. * envp stores environment variable strings' pointers in str_buf.
  40. */
  41. struct lwp_args_info
  42. {
  43. int argv0_strlen; /**< Length of argv[0] */
  44. int strings_length; /**< Total length of all argument strings */
  45. int str_buf_size; /**< Total size of str_buf */
  46. char *str_buf; /**< Buffer to store all argument strings */
  47. struct lwp_string_vector argv; /**< Vector of argument strings */
  48. struct lwp_string_vector envp; /**< Vector of environment variable strings */
  49. };
  50. rt_err_t lwp_args_init(struct lwp_args_info *ai);
  51. void lwp_args_detach(struct lwp_args_info *ai);
  52. struct process_aux *lwp_argscopy(struct rt_lwp *lwp, struct lwp_args_info *args_info);;
  53. rt_err_t lwp_args_put(struct lwp_args_info *args, const char **strv_addr, enum lwp_args_type atype);
  54. rt_err_t lwp_args_put_argv(struct lwp_args_info *args, const char **argv_uaddr);
  55. rt_err_t lwp_args_put_envp(struct lwp_args_info *args, const char **envp_uaddr);
  56. rt_err_t lwp_args_load_script(struct lwp_args_info *args, const char *filename);
  57. const char *lwp_args_get_argv_0(struct lwp_args_info *ai);
  58. char** lwp_get_envp(struct rt_lwp *lwp, rt_size_t *penvp_counts);
  59. void lwp_print_envp(struct rt_lwp *lwp);
  60. char** lwp_get_command_line_args(struct rt_lwp *lwp);
  61. void lwp_free_command_line_args(char** argv);
  62. #endif /* __LWP_ARGV_H__ */