X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/1375eb51603466b723ab7dd1ca4194ee5d662f75..b1644f824d7f4989a94b8a752aadee26cae25069:/lunaix-os/includes/hal/term.h diff --git a/lunaix-os/includes/hal/term.h b/lunaix-os/includes/hal/term.h index 84da769..07acec9 100644 --- a/lunaix-os/includes/hal/term.h +++ b/lunaix-os/includes/hal/term.h @@ -3,8 +3,9 @@ #include #include -#include +#include +#include #include struct term; @@ -16,57 +17,64 @@ struct linebuffer short sflags; short sz_hlf; }; -#define LSTATE_EOL (1) -#define LSTATE_EOF (1 << 1) -#define LSTATE_SIGRAISE (1 << 2) +#define LEVT_EOL (1) +#define LEVT_EOF (1 << 1) +#define LEVT_SIGRAISE (1 << 2) typedef struct rbuffer** lbuf_ref_t; #define ref_current(lbuf) (&(lbuf)->current) #define ref_next(lbuf) (&(lbuf)->next) #define deref(bref) (*(bref)) -struct term_lcntl +struct term; + +struct termport_pot_ops { + void (*set_speed)(struct device*, speed_t); + void (*set_clkbase)(struct device*, unsigned int); + void (*set_cntrl_mode)(struct device*, tcflag_t); +}; + +struct termport_potens +{ + POTENS_META; + struct termport_pot_ops* ops; struct term* term; - int (*process_and_put)(struct term*, struct linebuffer*, char); }; struct term { struct device* dev; struct device* chdev; - struct term_lcntl* lcntl; struct linebuffer line_out; struct linebuffer line_in; + char* scratch_pad; pid_t fggrp; - struct - { - int (*set_speed)(struct device*, speed_t); - } chdev_ops; + struct termport_potens* tp_cap; + waitq_t line_in_event; /* -- POSIX.1-2008 compliant fields -- */ tcflag_t iflags; tcflag_t oflags; tcflag_t lflags; + tcflag_t cflags; cc_t cc[_NCCS]; + + /* -- END POSIX.1-2008 compliant fields -- */ speed_t iospeed; + speed_t clkbase; + tcflag_t tflags; // temp flags }; -struct term* -term_create(struct device* chardev, char* suffix); - -int -term_bind(struct term* tdev, struct device* chdev); +extern struct device* sysconsole; -int -term_push_lcntl(struct term* tdev, struct term_lcntl* lcntl); +struct termport_potens* +term_attach_potens(struct device* chardev, + struct termport_pot_ops* ops, char* suffix); int -term_pop_lcntl(struct term* tdev); - -struct term_lcntl* -term_get_lcntl(u32_t lcntl_index); +term_bind(struct term* tdev, struct device* chdev); static inline void line_flip(struct linebuffer* lbf) @@ -97,4 +105,7 @@ lcntl_transform_inseq(struct term* tdev); int lcntl_transform_outseq(struct term* tdev); +void +term_notify_data_avaliable(struct termport_potens* cap); + #endif /* __LUNAIX_TERM_H */